AvroSchemaGenerator 2.10.0
dotnet add package AvroSchemaGenerator --version 2.10.0
NuGet\Install-Package AvroSchemaGenerator -Version 2.10.0
<PackageReference Include="AvroSchemaGenerator" Version="2.10.0" />
paket add AvroSchemaGenerator --version 2.10.0
#r "nuget: AvroSchemaGenerator, 2.10.0"
// Install AvroSchemaGenerator as a Cake Addin #addin nuget:?package=AvroSchemaGenerator&version=2.10.0 // Install AvroSchemaGenerator as a Cake Tool #tool nuget:?package=AvroSchemaGenerator&version=2.10.0
AvroSchemaGenerator
Use to generate Avro Schema with support for RECURSIVE SCHEMA
Getting Started
Install the NuGet package AvroSchemaGenerator and copy/paste the code below
using AvroSchemaGenerator;
public class Course
{
public string Level { get; set; }
public int Year { get; set; }
public string State { get; set; }
public string Gender { get; set; }
}
var avroSchema = typeof(Course).GetSchema();
By default, AvroSchemaGenerator
generates schema with optional fields. The code below is an example of how to mark fields as required
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using AvroSchemaGenerator;
public class Course
{
[Required]
public string Level { get; set; }
[Required]
public int Year { get; set; }
[Required]
public string State { get; set; }
[Required]
public string Gender { get; set; }
}
var avroSchema = typeof(Course).GetSchema();
You can assign a default value as well
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using AvroSchemaGenerator;
public class Course
{
[DefaultValue("200")]
[Required]
public string Level { get; set; }
[Required]
public int Year { get; set; }
[DefaultValue("Closed")]
public string State { get; set; }
public string Gender { get; set; }
}
var avroSchema = typeof(Course).GetSchema();
Aliases
[Aliases("OldCourse")]
public class Course
{
[Aliases("Level")]
public string NewLevel { get; set; }
}
Logical Types
public class MessageTimeKind
{
[LogicalType(LogicalTypeKind.TimeMicrosecond)]
public TimeSpan TimeMicros { get; set; }
[LogicalType(LogicalTypeKind.TimeMillisecond)]
public TimeSpan TimeMillis { get; set; }
}
public class MessageTimestampKind
{
[LogicalType(LogicalTypeKind.TimestampMicrosecond)]
public DateTime StampMicros { get; set; }
[LogicalType(LogicalTypeKind.TimestampMillisecond)]
public DateTime StampMillis { get; set; }
}
public class MessageDateKind
{
[LogicalType(LogicalTypeKind.Date)]
public DateTime CreatedTime { get; set; }
public AvroDecimal Size { get; set; }
public string DayOfWeek { get; set; }
}
Custom Avro Definition
public class CustomDefinition
{
[AvroSchema("{\n" +
" \"type\": \"bytes\",\n" +
" \"logicalType\": \"decimal\",\n" +
" \"precision\": 10,\n" +
" \"scale\": 6\n" +
"}")]
public AvroDecimal DecimalAvro { get; set; }
}
NOTE
- Don't use same declaring type as dictionary value
- Don't use same declaring type as list argument
- Dictionary key must be a string type
License
This project is licensed under the Apache License Version 2.0 - see the LICENSE file for details.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- System.ComponentModel.Annotations (>= 5.0.0)
- System.Text.Json (>= 8.0.0)
-
net7.0
- System.ComponentModel.Annotations (>= 5.0.0)
- System.Text.Json (>= 8.0.0)
-
net8.0
- System.ComponentModel.Annotations (>= 5.0.0)
- System.Text.Json (>= 8.0.0)
NuGet packages (3)
Showing the top 3 NuGet packages that depend on AvroSchemaGenerator:
Package | Downloads |
---|---|
Pulsar.Client
.NET client library for Apache Pulsar |
|
Pulsar.Client.Otel
OpenTelemetry plugin for Pulsar.Client |
|
SharpPulsar
SharpPulsar is Apache Pulsar Client built using Akka.net |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
2.10.0 | 7,823 | 12/16/2023 |
2.9.2 | 318,666 | 7/10/2023 |
2.9.1 | 1,461 | 3/19/2023 |
2.9.0 | 516 | 2/4/2023 |
2.9.0-rc.39 | 154 | 2/3/2023 |
2.9.0-rc.15 | 152 | 1/9/2023 |
2.9.0-rc.6 | 137 | 1/9/2023 |
2.8.1 | 104,710 | 1/9/2023 |
2.8.0 | 374 | 12/24/2022 |
2.8.0-rc.22 | 136 | 12/24/2022 |
2.8.0-rc.21 | 131 | 12/24/2022 |
2.8.0-rc.13 | 132 | 12/24/2022 |
2.8.0-rc.6 | 138 | 12/24/2022 |
2.7.0 | 154,441 | 7/20/2022 |
2.7.0-rc.139 | 157 | 7/20/2022 |
2.7.0-rc.138 | 148 | 7/20/2022 |
2.6.0 | 173,342 | 2/20/2022 |
2.6.0-rc.136 | 172 | 7/19/2022 |
2.5.2-alpha.2 | 177 | 1/16/2022 |
2.5.2-Alpha.1 | 168 | 1/16/2022 |
2.5.1 | 360 | 1/13/2022 |
2.5.0 | 466 | 12/26/2021 |
2.4.1 | 1,258 | 10/27/2021 |
2.4.0 | 51,620 | 9/28/2021 |
2.4.0-beta | 276 | 9/28/2021 |
2.3.3 | 942 | 9/15/2021 |
2.3.3-beta | 302 | 9/15/2021 |
2.3.2 | 382 | 9/15/2021 |
2.3.1-beta | 288 | 9/15/2021 |
2.3.0 | 427 | 9/15/2021 |
2.2.0 | 747 | 9/13/2021 |
2.2.0-beta.17 | 219 | 9/13/2021 |
2.1.0 | 778 | 9/11/2021 |
2.1.0-beta.16 | 236 | 9/13/2021 |
2.1.0-beta.15 | 289 | 9/11/2021 |
2.0.0 | 794 | 9/10/2021 |
2.0.0-beta.14 | 224 | 9/9/2021 |
1.9.0 | 52,752 | 4/14/2021 |
1.9.0-beta.13 | 251 | 9/9/2021 |
1.9.0-beta.12 | 221 | 4/14/2021 |
1.9.0-beta.11 | 204 | 4/14/2021 |
1.9.0-beta.10 | 206 | 4/13/2021 |
1.9.0-beta.9 | 202 | 4/13/2021 |
1.9.0-beta.5 | 193 | 4/13/2021 |
1.9.0-beta.3 | 190 | 4/13/2021 |
1.9.0-beta.2 | 235 | 4/11/2021 |
1.8.0 | 143,038 | 12/10/2020 |
1.7.0 | 631 | 11/4/2020 |
1.6.0 | 58,453 | 6/26/2020 |
1.5.4 | 524 | 6/21/2020 |
1.5.3 | 6,170 | 5/27/2020 |
1.5.2 | 4,798 | 5/13/2020 |
1.5.1 | 1,199 | 5/13/2020 |
1.5.0 | 510 | 5/13/2020 |
1.4.1 | 544 | 5/11/2020 |
1.4.0 | 520 | 5/11/2020 |
1.3.0 | 1,495 | 4/30/2020 |
1.2.0 | 547 | 4/28/2020 |
1.1.0 | 842 | 4/27/2020 |
1.0.0 | 521 | 4/27/2020 |
0.1.2 | 1,576 | 4/14/2020 |
0.1.1 | 512 | 4/14/2020 |
0.1.0 | 1,257 | 4/11/2020 |
• [Add] net8.0
• [update] NUKE 7.0.6
• [Added] CODE OF CONDUCT
Full changelog at https://github.com/Sharp-Pulsar/AvroSchemaGenerator/blob/refs/tags/2.10.0/CHANGELOG.md