-
Notifications
You must be signed in to change notification settings - Fork 4.5k
/
StoreReadSettings.Serialization.cs
130 lines (115 loc) · 6.61 KB
/
StoreReadSettings.Serialization.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
// <auto-generated/>
#nullable disable
using System;
using System.ClientModel.Primitives;
using System.Text.Json;
using Azure.Core;
namespace Azure.ResourceManager.DataFactory.Models
{
[PersistableModelProxy(typeof(UnknownStoreReadSettings))]
public partial class StoreReadSettings : IUtf8JsonSerializable, IJsonModel<StoreReadSettings>
{
void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel<StoreReadSettings>)this).Write(writer, ModelSerializationExtensions.WireOptions);
void IJsonModel<StoreReadSettings>.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options)
{
var format = options.Format == "W" ? ((IPersistableModel<StoreReadSettings>)this).GetFormatFromOptions(options) : options.Format;
if (format != "J")
{
throw new FormatException($"The model {nameof(StoreReadSettings)} does not support writing '{format}' format.");
}
writer.WriteStartObject();
writer.WritePropertyName("type"u8);
writer.WriteStringValue(StoreReadSettingsType);
if (Optional.IsDefined(MaxConcurrentConnections))
{
writer.WritePropertyName("maxConcurrentConnections"u8);
JsonSerializer.Serialize(writer, MaxConcurrentConnections);
}
if (Optional.IsDefined(DisableMetricsCollection))
{
writer.WritePropertyName("disableMetricsCollection"u8);
JsonSerializer.Serialize(writer, DisableMetricsCollection);
}
foreach (var item in AdditionalProperties)
{
writer.WritePropertyName(item.Key);
#if NET6_0_OR_GREATER
writer.WriteRawValue(item.Value);
#else
using (JsonDocument document = JsonDocument.Parse(item.Value))
{
JsonSerializer.Serialize(writer, document.RootElement);
}
#endif
}
writer.WriteEndObject();
}
StoreReadSettings IJsonModel<StoreReadSettings>.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options)
{
var format = options.Format == "W" ? ((IPersistableModel<StoreReadSettings>)this).GetFormatFromOptions(options) : options.Format;
if (format != "J")
{
throw new FormatException($"The model {nameof(StoreReadSettings)} does not support reading '{format}' format.");
}
using JsonDocument document = JsonDocument.ParseValue(ref reader);
return DeserializeStoreReadSettings(document.RootElement, options);
}
internal static StoreReadSettings DeserializeStoreReadSettings(JsonElement element, ModelReaderWriterOptions options = null)
{
options ??= ModelSerializationExtensions.WireOptions;
if (element.ValueKind == JsonValueKind.Null)
{
return null;
}
if (element.TryGetProperty("type", out JsonElement discriminator))
{
switch (discriminator.GetString())
{
case "AmazonS3CompatibleReadSettings": return AmazonS3CompatibleReadSettings.DeserializeAmazonS3CompatibleReadSettings(element, options);
case "AmazonS3ReadSettings": return AmazonS3ReadSettings.DeserializeAmazonS3ReadSettings(element, options);
case "AzureBlobFSReadSettings": return AzureBlobFSReadSettings.DeserializeAzureBlobFSReadSettings(element, options);
case "AzureBlobStorageReadSettings": return AzureBlobStorageReadSettings.DeserializeAzureBlobStorageReadSettings(element, options);
case "AzureDataLakeStoreReadSettings": return AzureDataLakeStoreReadSettings.DeserializeAzureDataLakeStoreReadSettings(element, options);
case "AzureFileStorageReadSettings": return AzureFileStorageReadSettings.DeserializeAzureFileStorageReadSettings(element, options);
case "FileServerReadSettings": return FileServerReadSettings.DeserializeFileServerReadSettings(element, options);
case "FtpReadSettings": return FtpReadSettings.DeserializeFtpReadSettings(element, options);
case "GoogleCloudStorageReadSettings": return GoogleCloudStorageReadSettings.DeserializeGoogleCloudStorageReadSettings(element, options);
case "HdfsReadSettings": return HdfsReadSettings.DeserializeHdfsReadSettings(element, options);
case "HttpReadSettings": return HttpReadSettings.DeserializeHttpReadSettings(element, options);
case "LakeHouseReadSettings": return LakeHouseReadSettings.DeserializeLakeHouseReadSettings(element, options);
case "OracleCloudStorageReadSettings": return OracleCloudStorageReadSettings.DeserializeOracleCloudStorageReadSettings(element, options);
case "SftpReadSettings": return SftpReadSettings.DeserializeSftpReadSettings(element, options);
}
}
return UnknownStoreReadSettings.DeserializeUnknownStoreReadSettings(element, options);
}
BinaryData IPersistableModel<StoreReadSettings>.Write(ModelReaderWriterOptions options)
{
var format = options.Format == "W" ? ((IPersistableModel<StoreReadSettings>)this).GetFormatFromOptions(options) : options.Format;
switch (format)
{
case "J":
return ModelReaderWriter.Write(this, options);
default:
throw new FormatException($"The model {nameof(StoreReadSettings)} does not support writing '{options.Format}' format.");
}
}
StoreReadSettings IPersistableModel<StoreReadSettings>.Create(BinaryData data, ModelReaderWriterOptions options)
{
var format = options.Format == "W" ? ((IPersistableModel<StoreReadSettings>)this).GetFormatFromOptions(options) : options.Format;
switch (format)
{
case "J":
{
using JsonDocument document = JsonDocument.Parse(data);
return DeserializeStoreReadSettings(document.RootElement, options);
}
default:
throw new FormatException($"The model {nameof(StoreReadSettings)} does not support reading '{options.Format}' format.");
}
}
string IPersistableModel<StoreReadSettings>.GetFormatFromOptions(ModelReaderWriterOptions options) => "J";
}
}