KubeOps.Generator
9.2.0
dotnet add package KubeOps.Generator --version 9.2.0
NuGet\Install-Package KubeOps.Generator -Version 9.2.0
<PackageReference Include="KubeOps.Generator" Version="9.2.0"> <PrivateAssets>all</PrivateAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets> </PackageReference>
paket add KubeOps.Generator --version 9.2.0
#r "nuget: KubeOps.Generator, 9.2.0"
// Install KubeOps.Generator as a Cake Addin #addin nuget:?package=KubeOps.Generator&version=9.2.0 // Install KubeOps.Generator as a Cake Tool #tool nuget:?package=KubeOps.Generator&version=9.2.0
KubeOps Generator
This is a C# source generator for KubeOps and operators. It is used to generate convenience functions to help registering resources within an operator.
Usage
The generator is automatically used when the KubeOps.Generator
package is referenced.
dotnet add package KubeOps.Generator
which results in the following csproj
reference:
<ItemGroup>
<PackageReference Include="KubeOps.Generator" Version="...">
<PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets>
</PackageReference>
</ItemGroup>
Generated Sources
The generator will automatically generate functions for the IOperatorBuilder
.
Entity Metadata / Entity Definitions
The generator creates a file in the root namespace called EntityDefinitions.g.cs
.
This file contains all entities that are annotated with the KubernetesEntityAttribute
.
The static class contains the EntityMetadata
for the entities as well
as a function to register all entities within the IOperatorBuilder
.
Example
using KubeOps.Abstractions.Builder;
using KubeOps.Abstractions.Entities;
public static class EntityDefinitions
{
public static readonly EntityMetadata V1TestEntity = new("TestEntity", "v1", "testing.dev", null);
public static IOperatorBuilder RegisterEntities(this IOperatorBuilder builder)
{
builder.AddEntity<global::Operator.Entities.V1TestEntity>(V1TestEntity);
return builder;
}
}
Entity Initializer
All entities must have their Kind
and ApiVersion
fields set.
To achieve this, the generator creates an initializer file for each entity
that is annotated with the KubernetesEntityAttribute
.
For each partial class that does not contain a default constructor,
the generator will create a default constructor that sets the Kind
and ApiVersion
fields.
For each non partial class, a method extension is created that sets
the Kind
and ApiVersion
fields.
[!NOTE] Setting your class partial is crucial for the generator to create the constructor. Also, if some default constructor is already present, the generator uses the method extension fallback.
Example
namespace Operator.Entities;
[KubernetesEntity(Group = "testing.dev", ApiVersion = "v1", Kind = "TestEntity")]
public partial class V1TestEntity : CustomKubernetesEntity
{
}
The partial defined entity above will generate the following V1TestEntity.init.g.cs
file:
namespace Operator.Entities;
public partial class V1TestEntity
{
public V1TestEntity()
{
ApiVersion = "testing.dev/v1";
Kind = "TestEntity";
}
}
The non partial defined entity below:
namespace Operator.Entities;
[KubernetesEntity(Group = "testing.dev", ApiVersion = "v1", Kind = "TestEntity")]
public class V1TestEntity : CustomKubernetesEntity
{
}
will generate a static method extension in EntityInitializer.g.cs
for the entity to initialize the fields:
public static class EntityInitializer
{
public static global::Operator.Entities.V1ClusterTestEntity Initialize(this global::Operator.Entities.V1ClusterTestEntity entity)
{
entity.ApiVersion = "testing.dev/v1";
entity.Kind = "ClusterTestEntity";
return entity;
}
}
Controller Registrations
The generator creates a file in the root namespace called ControllerRegistrations.g.cs
.
This file contains a function to register all found controllers
(i.e. classes that implement the IEntityController<T>
interface).
Example
using KubeOps.Abstractions.Builder;
public static class ControllerRegistrations
{
public static IOperatorBuilder RegisterControllers(this IOperatorBuilder builder)
{
builder.AddController<global::Operator.Controller.V1TestEntityController, global::Operator.Entities.V1TestEntity>();
return builder;
}
}
Finalizer Registrations
The generator creates a file in the root namespace called FinalizerRegistrations.g.cs
.
This file contains all finalizers with generated finalizer-identifiers.
Further, a function to register all finalizers is generated.
Example
using KubeOps.Abstractions.Builder;
public static class FinalizerRegistrations
{
public const string FinalizerOneIdentifier = "testing.dev/finalizeronefinalizer";
public const string FinalizerTwoIdentifier = "testing.dev/finalizertwofinalizer";
public static IOperatorBuilder RegisterFinalizers(this IOperatorBuilder builder)
{
builder.AddFinalizer<global::Operator.Finalizer.FinalizerOne, global::Operator.Entities.V1TestEntity>(FinalizerOneIdentifier);
builder.AddFinalizer<global::Operator.Finalizer.FinalizerTwo, global::Operator.Entities.V1TestEntity>(FinalizerTwoIdentifier);
return builder;
}
}
General Operator Extensions
The generator creates a file in the root namespace called OperatorExtensions.g.cs
.
It contains convenience functions to register all generated sources.
Example
using KubeOps.Abstractions.Builder;
public static class OperatorBuilderExtensions
{
public static IOperatorBuilder RegisterComponents(this IOperatorBuilder builder)
{
builder.RegisterEntities();
builder.RegisterControllers();
builder.RegisterFinalizers();
return builder;
}
}
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 was computed. 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 was computed. 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. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.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
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on KubeOps.Generator:
Repository | Stars |
---|---|
josephnhtam/live-streaming-server-net
A .NET implementation of RTMP live streaming server, supporting HTTP-FLV, WebSocket-FLV, HLS, Kubernetes, cloud storage services integration and more.
|
Version | Downloads | Last updated |
---|---|---|
9.2.0 | 32 | 1/24/2025 |
9.1.5 | 7,795 | 9/10/2024 |
9.1.4 | 1,126 | 8/26/2024 |
9.1.3 | 7,050 | 6/28/2024 |
9.1.2 | 665 | 6/20/2024 |
9.1.1 | 1,859 | 5/22/2024 |
9.1.0 | 1,935 | 5/15/2024 |
9.0.2 | 153 | 5/13/2024 |
9.0.0 | 9,676 | 3/13/2024 |
9.0.0-pre.4 | 80 | 4/19/2024 |
9.0.0-pre.3 | 71 | 3/21/2024 |
9.0.0-pre.2 | 69 | 3/13/2024 |
9.0.0-pre.1 | 65 | 3/7/2024 |
8.0.2-pre.2 | 81 | 2/21/2024 |
8.0.2-pre.1 | 64 | 2/19/2024 |
8.0.1 | 2,411 | 2/13/2024 |
8.0.1-pre.7 | 71 | 2/12/2024 |
8.0.1-pre.6 | 74 | 2/7/2024 |
8.0.1-pre.5 | 73 | 2/5/2024 |
8.0.1-pre.4 | 75 | 1/31/2024 |
8.0.1-pre.3 | 74 | 1/26/2024 |
8.0.1-pre.2 | 70 | 1/25/2024 |
8.0.1-pre.1 | 71 | 1/18/2024 |
8.0.0 | 653 | 1/17/2024 |
8.0.0-pre.45 | 62 | 1/17/2024 |
8.0.0-pre.44 | 65 | 1/16/2024 |
8.0.0-pre.43 | 76 | 1/16/2024 |
8.0.0-pre.42 | 1,179 | 1/10/2024 |
8.0.0-pre.41 | 200 | 1/2/2024 |
8.0.0-pre.40 | 171 | 12/27/2023 |
8.0.0-pre.39 | 87 | 12/21/2023 |
8.0.0-pre.38 | 191 | 12/6/2023 |
8.0.0-pre.37 | 105 | 12/6/2023 |
8.0.0-pre.36 | 145 | 12/3/2023 |
8.0.0-pre.35 | 82 | 11/28/2023 |
8.0.0-pre.34 | 97 | 11/24/2023 |
8.0.0-pre.33 | 73 | 11/24/2023 |
8.0.0-pre.32 | 74 | 11/23/2023 |
8.0.0-pre.31 | 78 | 11/23/2023 |
8.0.0-pre.30 | 86 | 11/23/2023 |
8.0.0-pre.29 | 466 | 11/11/2023 |
8.0.0-pre.28 | 97 | 11/8/2023 |
8.0.0-pre.27 | 600 | 10/23/2023 |
8.0.0-pre.26 | 102 | 10/19/2023 |
8.0.0-pre.25 | 78 | 10/18/2023 |
8.0.0-pre.24 | 102 | 10/13/2023 |
8.0.0-pre.23 | 78 | 10/13/2023 |
8.0.0-pre.22 | 82 | 10/13/2023 |
8.0.0-pre.21 | 83 | 10/12/2023 |
8.0.0-pre.20 | 89 | 10/11/2023 |
8.0.0-pre.19 | 92 | 10/9/2023 |
8.0.0-pre.18 | 78 | 10/9/2023 |
8.0.0-pre.17 | 75 | 10/7/2023 |
8.0.0-pre.16 | 114 | 10/6/2023 |
8.0.0-pre.15 | 84 | 10/6/2023 |
8.0.0-pre.14 | 77 | 10/5/2023 |
8.0.0-pre.13 | 71 | 10/5/2023 |
8.0.0-pre.12 | 79 | 10/4/2023 |
8.0.0-pre.11 | 80 | 10/3/2023 |
8.0.0-pre.10 | 87 | 10/3/2023 |
8.0.0-pre.9 | 84 | 10/3/2023 |
8.0.0-pre.8 | 74 | 10/2/2023 |
8.0.0-pre.7 | 81 | 10/2/2023 |
8.0.0-pre.6 | 78 | 9/29/2023 |
8.0.0-pre.5 | 78 | 9/28/2023 |
8.0.0-pre.4 | 75 | 9/28/2023 |
8.0.0-pre.3 | 80 | 9/27/2023 |
8.0.0-pre.2 | 63 | 9/26/2023 |
8.0.0-pre.1 | 80 | 9/22/2023 |
'# [9.2.0](https://github.com/buehler/dotnet-operator-sdk/compare/v9.1.5...v9.2.0) (2025-01-24)
### Bug Fixes
* Default to setting Nullable to null in CRD generation ([#830](https://github.com/buehler/dotnet-operator-sdk/issues/830)) ([5e061d5](https://github.com/buehler/dotnet-operator-sdk/commit/5e061d5093984413b534598bc7c578a326af134c))
* **deps:** upgrade localtunnel ([#814](https://github.com/buehler/dotnet-operator-sdk/issues/814)) ([307835e](https://github.com/buehler/dotnet-operator-sdk/commit/307835efbfc3676c9794f9d75ee72e2f5095f470))
* Limit the number of types to process ([#816](https://github.com/buehler/dotnet-operator-sdk/issues/816)) ([092ae45](https://github.com/buehler/dotnet-operator-sdk/commit/092ae455b3eebd1ce874af54e4118102d86f510b))
* Set KubeOps.Generator as a DevelopmentDependency ([#834](https://github.com/buehler/dotnet-operator-sdk/issues/834)) ([5a98290](https://github.com/buehler/dotnet-operator-sdk/commit/5a982901bd85ad82587a809be588b6fd5b7371de)), closes [#698](https://github.com/buehler/dotnet-operator-sdk/issues/698)
### Features
* Add EnumMemberAttribute and .NET 9's JsonStringEnumMemberNameAttribute ([#833](https://github.com/buehler/dotnet-operator-sdk/issues/833)) ([c9beb6d](https://github.com/buehler/dotnet-operator-sdk/commit/c9beb6de97346ada5507f2d60d72321b97085481))
* Add support for generating CRD's for entities that contain other custom resources ([#823](https://github.com/buehler/dotnet-operator-sdk/issues/823)) ([f2129cf](https://github.com/buehler/dotnet-operator-sdk/commit/f2129cf746f928a431fd855dcf2736e3dbb819af))
* upgrade to dotnet 9 ([#838](https://github.com/buehler/dotnet-operator-sdk/issues/838)) ([9b905fb](https://github.com/buehler/dotnet-operator-sdk/commit/9b905fbe7b37077b779b9bae5d340057c3dd8ad8))
'