Compare commits

...

30 Commits

Author SHA1 Message Date
81af585e5f Update nuget packages 2026-01-03 15:09:46 +01:00
13345520ac Cleanups 2026-01-03 11:16:24 +01:00
5f03bef2d3 Update to centralized packages management 2026-01-03 11:16:02 +01:00
42521a0e12 Update nuget packages 2026-01-03 11:00:00 +01:00
73f7e585bc Update nuget packages 2026-01-02 14:55:04 +01:00
ecc60a9c8d Upgrade to .Net 10 2026-01-02 13:34:17 +01:00
05a79de31e Update nuget packags 2025-10-12 15:06:35 +02:00
3f0b736589 Update to new structure 2025-09-22 17:10:31 +02:00
37d65c9c84 Update nuget packages 2025-09-22 11:22:29 +02:00
6a4a62672a Update nuget packages 2025-09-22 11:19:19 +02:00
a33f626fb0 Update nuget packages 2025-09-22 11:03:42 +02:00
45c2dc2acf Update examples 2025-01-30 17:03:38 +01:00
a0cd811287 Update nuget packages 2023-12-18 12:27:08 +01:00
ae2aab0556 Fix formattings 2023-12-18 12:19:32 +01:00
3d034f3d4d Fix exapmples 2023-12-18 12:10:34 +01:00
e390644d35 Fix projects 2023-12-14 17:52:33 +01:00
8ebab4f3fe Update packages 2023-08-27 07:49:45 +02:00
6e45fee6c8 Update nuget packages 2023-08-24 21:56:20 +02:00
6d7e447ccc Use file scoped namepace 2022-12-22 15:29:53 +01:00
27bf5f0b24 Fix consfiguration 2022-12-22 09:19:09 +01:00
c96bbc3495 Update nuget packages 2022-12-22 09:17:56 +01:00
302862fee4 Fix example 2022-12-22 08:32:15 +01:00
561f4f91aa Update packages 2022-12-21 15:43:16 +01:00
5cfbc1e799 Update nuge packages 2022-12-21 15:22:13 +01:00
13d7db3a82 Update to .net7.0 2022-12-21 15:21:04 +01:00
5e9c5d1c48 Update nuget packages 2022-03-09 14:08:51 +01:00
b127f9d8d9 Update o .net6.0 2021-12-20 22:54:05 +01:00
ba18772576 Update nuget packages 2021-07-23 14:36:31 +02:00
cf2f5a20fd Renamings 2021-07-15 22:31:00 +02:00
6dfb18ef5b update appsettings 2021-07-15 22:29:10 +02:00
66 changed files with 1194 additions and 1156 deletions

19
Directory.Build.props Normal file
View File

@@ -0,0 +1,19 @@
<Project>
<PropertyGroup>
<TargetFramework>net10.0</TargetFramework>
<LangVersion>latest</LangVersion>
<ImplicitUsings>enable</ImplicitUsings>
<Nullable>disable</Nullable>
</PropertyGroup>
<ItemGroup>
<ProjectCapability Include="ConfigurableFileNesting" />
<ProjectCapability Include="ConfigurableFileNestingFeatureEnabled" />
</ItemGroup>
<ItemGroup>
<Content Update="@(Content)">
<Visible Condition="'%(NuGetItemType)' == 'Content'">false</Visible>
</Content>
</ItemGroup>
</Project>

40
Directory.Packages.props Normal file
View File

@@ -0,0 +1,40 @@
<Project>
<PropertyGroup>
<ManagePackageVersionsCentrally>true</ManagePackageVersionsCentrally>
<CentralPackageTransitivePinningEnabled>true</CentralPackageTransitivePinningEnabled>
</PropertyGroup>
<ItemGroup>
</ItemGroup>
<ItemGroup>
<PackageVersion Include="AutoMapper" Version="16.0.0" />
<PackageVersion Include="FluentValidation" Version="12.1.1" />
<PackageVersion Include="GerstITS.Authentication.OpenId" Version="2026.1.1" />
<PackageVersion Include="GerstITS.Common" Version="2025.12.1" />
<PackageVersion Include="GerstITS.Data" Version="2026.1.3" />
<PackageVersion Include="GerstITS.Data.EntityFramework" Version="2026.1.3" />
<PackageVersion Include="GerstITS.Data.EntityFramework.PostgreSql" Version="2026.1.1" />
<PackageVersion Include="GerstITS.IoC" Version="2025.12.1" />
<PackageVersion Include="GerstITS.IoC.DotNetCore" Version="2025.12.1" />
<PackageVersion Include="GerstITS.Job" Version="2025.12.1" />
<PackageVersion Include="GerstITS.Job.Scheduling" Version="2026.1.1" />
<PackageVersion Include="GerstITS.Mapping.AutoMapper" Version="2026.1.1" />
<PackageVersion Include="GerstITS.Search" Version="2026.1.1" />
<PackageVersion Include="GerstITS.System" Version="2026.1.1" />
<PackageVersion Include="GerstITS.Validation" Version="2026.1.1" />
<PackageVersion Include="GerstITS.Web" Version="2025.12.1" />
<PackageVersion Include="GerstITS.Web.Api" Version="2026.1.1" />
<PackageVersion Include="GerstITS.Web.Api.Swagger" Version="2026.1.4" />
<PackageVersion Include="GerstITS.Web.Rest" Version="2026.1.1" />
<PackageVersion Include="Hocon.Extensions.Configuration" Version="2.0.4" />
<PackageVersion Include="Microsoft.AspNetCore.Mvc.NewtonsoftJson" Version="10.0.1" />
<PackageVersion Include="Microsoft.EntityFrameworkCore" Version="10.0.1" />
<PackageVersion Include="Microsoft.EntityFrameworkCore.Design" Version="10.0.1" />
<PackageVersion Include="Microsoft.EntityFrameworkCore.Tools" Version="10.0.1" />
<PackageVersion Include="Microsoft.Extensions.Configuration.FileExtensions" Version="10.0.1" />
<PackageVersion Include="Microsoft.Extensions.Configuration.Json" Version="10.0.1" />
<PackageVersion Include="Microsoft.Extensions.DependencyInjection.Abstractions" Version="10.0.1" />
<PackageVersion Include="Newtonsoft.Json" Version="13.0.4" />
<PackageVersion Include="Npgsql.EntityFrameworkCore.PostgreSQL" Version="10.0.0" />
<PackageVersion Include="Serilog.AspNetCore" Version="10.0.0" />
</ItemGroup>
</Project>

View File

@@ -1,29 +1,24 @@
using System; namespace GerstITS.Examples.Api.Configurations;
using System.Linq;
using Microsoft.Extensions.Configuration;
namespace GerstITS.Examples.Api.Configurations public static class IConfigurationExtensions
{ {
public static class IConfigurationExtensions #region Methods
public static TEnum GetFlaggedEnum<TEnum>(this IConfiguration configuration, string key)
where TEnum : struct, IConvertible
{ {
#region Methods ThrowsAnExceptionIfTypeIsNotAnEnumeration<TEnum>();
public static TEnum GetFlaggedEnum<TEnum>(this IConfiguration configuration, string key) return (TEnum)(object)(configuration.GetSection(key)?
where TEnum : struct, IConvertible .Get<TEnum[]>() ?? Enumerable.Empty<TEnum>())
{ .Sum(i => (int)(object)i);
ThrowsAnExceptionIfTypeIsNotAnEnumeration<TEnum>();
return (TEnum)(object)(configuration.GetSection(key)?
.Get<TEnum[]>() ?? Enumerable.Empty<TEnum>())
.Sum(i => (int)(object)i);
}
private static void ThrowsAnExceptionIfTypeIsNotAnEnumeration<TEnum>() where TEnum : struct, IConvertible
{
if (!typeof(TEnum).IsEnum)
throw new InvalidOperationException($"{typeof(TEnum)} is not supported.");
}
#endregion
} }
}
private static void ThrowsAnExceptionIfTypeIsNotAnEnumeration<TEnum>() where TEnum : struct, IConvertible
{
if (!typeof(TEnum).IsEnum)
throw new InvalidOperationException($"{typeof(TEnum)} is not supported.");
}
#endregion
}

View File

@@ -1,27 +1,25 @@
using GerstITS.Data.EntityFramework; using GerstITS.Data.EntityFramework;
using GerstITS.System.Configurations; using GerstITS.System.Configurations;
using Microsoft.Extensions.Configuration;
namespace GerstITS.Examples.Api.Configurations namespace GerstITS.Examples.Api.Configurations;
internal sealed class EntityFrameworkMigrationConfiguration : IEntityFrameworkMigrationConfiguration
{ {
internal sealed class EntityFrameworkMigrationConfiguration : IEntityFrameworkMigrationConfiguration #region Constructors
public EntityFrameworkMigrationConfiguration(string parentPrefix,
Microsoft.Extensions.Configuration.IConfiguration configuration)
{ {
#region Constructors var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
public EntityFrameworkMigrationConfiguration(string parentPrefix, AutoMigrate = configuration.GetValue<bool>($"{prefix}:{nameof(AutoMigrate)}");
Microsoft.Extensions.Configuration.IConfiguration configuration)
{
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
AutoMigrate = configuration.GetValue<bool>($"{prefix}:{nameof(AutoMigrate)}");
}
#endregion
#region IMigrationConfiguration
public bool AutoMigrate { get; }
#endregion
} }
#endregion
#region IMigrationConfiguration
public bool AutoMigrate { get; }
#endregion
} }

View File

@@ -1,34 +1,33 @@
using GerstITS.Web.Api.Swagger; using GerstITS.Web.Api.Swagger;
using Microsoft.Net.Http.Headers; using Microsoft.Net.Http.Headers;
using Microsoft.OpenApi.Models; using Microsoft.OpenApi;
namespace BakeTronic.Web.Api.Configurations namespace GerstITS.Examples.Api.Configurations;
internal sealed class OpenApiSecuritySchemeConfiguration : IOpenApiSecuritySchemeConfiguration
{ {
internal sealed class OpenApiSecuritySchemeConfiguration : IOpenApiSecuritySchemeConfiguration #region Properties
public bool AllowAnonymous { get; }
public string HttpHeaderKey { get; }
public string Scheme { get; }
public SecuritySchemeType SchemeType { get; }
public ParameterLocation ParameterLocation { get; }
public string Description { get; }
#endregion
#region Constructors
public OpenApiSecuritySchemeConfiguration()
{ {
#region Properties AllowAnonymous = false;
HttpHeaderKey = HeaderNames.Authorization;
Scheme = "Bearer";
SchemeType = SecuritySchemeType.Http;
ParameterLocation = ParameterLocation.Header;
Description = "Authorization header using the Bearer scheme (Value: Bearer {{access_token}}).";
}
public bool AllowAnonymous { get; } #endregion
public string HttpHeaderKey { get; }
public string Scheme { get; }
public SecuritySchemeType SchemeType { get; }
public ParameterLocation ParameterLocation { get; }
public string Description { get; }
#endregion
#region Constructors
public OpenApiSecuritySchemeConfiguration()
{
AllowAnonymous = false;
HttpHeaderKey = HeaderNames.Authorization;
Scheme = "Bearer";
SchemeType = SecuritySchemeType.Http;
ParameterLocation = ParameterLocation.Header;
Description = "Authorization header using the Bearer scheme (Value: Bearer {{access_token}}).";
}
#endregion
}
} }

View File

@@ -1,34 +1,32 @@
using GerstITS.Authentication.OpenId; using GerstITS.Authentication.OpenId;
using Microsoft.Extensions.Configuration;
namespace BakeTronic.Web.Api.Configurations namespace GerstITS.Examples.Api.Configurations;
internal class OpenIdValidationConfiguration : IOpenIdValidationConfiguration
{ {
internal class OpenIdValidationConfiguration : IOpenIdValidationConfiguration #region Constructors
public OpenIdValidationConfiguration(string parentPrefix,
IConfiguration configuration)
{ {
#region Constructors var prefix = $"{parentPrefix}:Validate";
public OpenIdValidationConfiguration(string parentPrefix, Issuer = configuration.GetValue<string>($"{prefix}:{nameof(Issuer)}");
IConfiguration configuration) Audience = configuration.GetValue<string>($"{prefix}:{nameof(Audience)}");
{ RsaPublicKey = configuration.GetValue<string>($"{prefix}:{nameof(RsaPublicKey)}");
var prefix = $"{parentPrefix}:Validate"; NameClaimType = configuration.GetValue<string>($"{prefix}:{nameof(NameClaimType)}");
ValidateLifetime = configuration.GetValue<bool>($"{prefix}:{nameof(ValidateLifetime)}");
Issuer = configuration.GetValue<string>($"{prefix}:{nameof(Issuer)}");
Audience = configuration.GetValue<string>($"{prefix}:{nameof(Audience)}");
RsaPublicKey = configuration.GetValue<string>($"{prefix}:{nameof(RsaPublicKey)}");
RequiredClaimType = configuration.GetValue<string>($"{prefix}:{nameof(RequiredClaimType)}");
ValidateLifetime = configuration.GetValue<bool>($"{prefix}:{nameof(ValidateLifetime)}");
}
#endregion
#region IOpenIdValidationConfiguration
public string Issuer { get; }
public string Audience { get; }
public string RsaPublicKey { get; }
public string RequiredClaimType { get; }
public bool ValidateLifetime { get; }
#endregion
} }
#endregion
#region IOpenIdValidationConfiguration
public string Issuer { get; }
public string Audience { get; }
public string RsaPublicKey { get; }
public string NameClaimType { get; }
public bool ValidateLifetime { get; }
#endregion
} }

View File

@@ -1,36 +1,33 @@
using BakeTronic.Web.Api.Configurations; using GerstITS.Authentication.OpenId;
using GerstITS.Authentication.OpenId;
using GerstITS.System.Configurations; using GerstITS.System.Configurations;
using Microsoft.Extensions.Configuration;
namespace GerstITS.Examples.Api.Configurations namespace GerstITS.Examples.Api.Configurations;
internal class OpenIdConfiguration : IOpenIdConfiguration
{ {
internal class OpenIdConfiguration : IOpenIdConfiguration #region Constructors
public OpenIdConfiguration(string parentPrefix,
Microsoft.Extensions.Configuration.IConfiguration configuration)
{ {
#region Constructors var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
public OpenIdConfiguration(string parentPrefix, Authority = configuration.GetValue<string>($"{prefix}:{nameof(Authority)}");
Microsoft.Extensions.Configuration.IConfiguration configuration) RequireHttpsMetadata = configuration.GetValue<bool>($"{prefix}:{nameof(RequireHttpsMetadata)}");
{ SaveToken = configuration.GetValue<bool>($"{prefix}:{nameof(SaveToken)}");
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
Authority = configuration.GetValue<string>($"{prefix}:{nameof(Authority)}"); Validate = new OpenIdValidationConfiguration(prefix, configuration);
RequireHttpsMetadata = configuration.GetValue<bool>($"{prefix}:{nameof(RequireHttpsMetadata)}"); }
SaveToken = configuration.GetValue<bool>($"{prefix}:{nameof(SaveToken)}");
Validate = new OpenIdValidationConfiguration(prefix, configuration);
}
#endregion #endregion
#region IOpenIdConfiguration #region IOpenIdConfiguration
public string Authority { get; } public string Authority { get; }
public bool RequireHttpsMetadata { get; } public bool RequireHttpsMetadata { get; }
public bool SaveToken { get; } public bool SaveToken { get; }
public IOpenIdValidationConfiguration Validate { get; } public IOpenIdValidationConfiguration Validate { get; }
#endregion #endregion
}
} }

View File

@@ -1,32 +1,30 @@
using GerstITS.System.Configurations; using GerstITS.System.Configurations;
using GerstITS.Web.Api.Builder; using GerstITS.Web.Api.Builder;
using Microsoft.Extensions.Configuration;
namespace BakeTronic.Web.Api.Configurations namespace GerstITS.Examples.Api.Configurations;
internal sealed class CorsPolicyConfiguration : ICorsPolicy, GerstITS.System.Configurations.IConfiguration
{ {
internal sealed class CorsPolicyConfiguration : ICorsPolicy, GerstITS.System.Configurations.IConfiguration #region Constructors
public CorsPolicyConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration)
{ {
#region Constructors var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
public CorsPolicyConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration) AllowCredentials = configuration.GetValue<bool>($"{prefix}:{nameof(AllowCredentials)}", false);
{ AllowedOrigins = configuration.GetSection($"{prefix}:{nameof(AllowedOrigins)}").Get<string[]>() ?? new string[0];
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}"; AllowedHeaders = configuration.GetSection($"{prefix}:{nameof(AllowedHeaders)}").Get<string[]>() ?? new string[0];
AllowedMethods = configuration.GetSection($"{prefix}:{nameof(AllowedMethods)}").Get<string[]>() ?? new string[0];
AllowCredentials = configuration.GetValue<bool>($"{prefix}:{nameof(AllowCredentials)}", false);
AllowedOrigins = configuration.GetSection($"{prefix}:{nameof(AllowedOrigins)}").Get<string[]>() ?? new string[0];
AllowedHeaders = configuration.GetSection($"{prefix}:{nameof(AllowedHeaders)}").Get<string[]>() ?? new string[0];
AllowedMethods = configuration.GetSection($"{prefix}:{nameof(AllowedMethods)}").Get<string[]>() ?? new string[0];
}
#endregion
#region ICorsPolicy
public bool AllowCredentials { get; }
public string[] AllowedOrigins { get; set; }
public string[] AllowedHeaders { get; set; }
public string[] AllowedMethods { get; set; }
#endregion
} }
#endregion
#region ICorsPolicy
public bool AllowCredentials { get; }
public string[] AllowedOrigins { get; set; }
public string[] AllowedHeaders { get; set; }
public string[] AllowedMethods { get; set; }
#endregion
} }

View File

@@ -1,30 +1,28 @@
using GerstITS.System.Configurations; using GerstITS.System.Configurations;
using GerstITS.Web.Api.Builder; using GerstITS.Web.Api.Builder;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.HttpOverrides; using Microsoft.AspNetCore.HttpOverrides;
namespace GerstITS.Examples.Api.Configurations namespace GerstITS.Examples.Api.Configurations;
internal sealed class WebApiHeadersConfiguration : IHeaderConfiguration, GerstITS.System.Configurations.IConfiguration
{ {
internal sealed class WebApiHeadersConfiguration : IHeaderConfiguration, IConfiguration #region Constructors
public WebApiHeadersConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration)
{ {
#region Constructors var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
public WebApiHeadersConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration) ForwardedHeaders = new ForwardedHeadersOptions
{ {
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}"; ForwardedHeaders = configuration.GetFlaggedEnum<ForwardedHeaders>($"{prefix}:{nameof(ForwardedHeadersOptions)}:{nameof(ForwardedHeadersOptions.ForwardedHeaders)}")
};
ForwardedHeaders = new ForwardedHeadersOptions
{
ForwardedHeaders = configuration.GetFlaggedEnum<ForwardedHeaders>($"{prefix}:{nameof(ForwardedHeadersOptions)}:{nameof(ForwardedHeadersOptions.ForwardedHeaders)}")
};
}
#endregion
#region IHeaderConfiguration
public ForwardedHeadersOptions ForwardedHeaders { get; }
#endregion
} }
#endregion
#region IHeaderConfiguration
public ForwardedHeadersOptions ForwardedHeaders { get; }
#endregion
} }

View File

@@ -1,36 +1,33 @@
using GerstITS.Examples.Api.Configurations; using GerstITS.System.Configurations;
using GerstITS.System.Configurations;
using GerstITS.Web.Api.Builder; using GerstITS.Web.Api.Builder;
using Microsoft.Extensions.Configuration;
namespace BakeTronic.Web.Api.Configurations namespace GerstITS.Examples.Api.Configurations;
internal sealed class ServerConfiguration : IServerConfiguration
{ {
internal sealed class ServerConfiguration : IServerConfiguration #region Constructors
public ServerConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration)
{ {
#region Constructors var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
public ServerConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration) UseHttpsRedirection = configuration.GetValue<bool>($"{prefix}:{nameof(UseHttpsRedirection)}");
{ UseHsts = configuration.GetValue<bool>($"{prefix}:{nameof(UseHsts)}");
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}"; UseCors = configuration.GetValue<bool>($"{prefix}:{nameof(UseCors)}");
UseHttpsRedirection = configuration.GetValue<bool>($"{prefix}:{nameof(UseHttpsRedirection)}"); Headers = new WebApiHeadersConfiguration(prefix, configuration);
UseHsts = configuration.GetValue<bool>($"{prefix}:{nameof(UseHsts)}"); CorsPolicy = new CorsPolicyConfiguration(prefix, configuration);
UseCors = configuration.GetValue<bool>($"{prefix}:{nameof(UseCors)}");
Headers = new WebApiHeadersConfiguration(prefix, configuration);
CorsPolicy = new CorsPolicyConfiguration(prefix, configuration);
}
#endregion
#region IServerConfiguration
public bool UseHttpsRedirection { get; }
public bool UseHsts { get; }
public bool UseCors { get; }
public IHeaderConfiguration Headers { get; }
public ICorsPolicy CorsPolicy { get; }
#endregion
} }
#endregion
#region IServerConfiguration
public bool UseHttpsRedirection { get; }
public bool UseHsts { get; }
public bool UseCors { get; }
public IHeaderConfiguration Headers { get; }
public ICorsPolicy CorsPolicy { get; }
#endregion
} }

View File

@@ -1,29 +1,26 @@
using System; using GerstITS.System.Configurations;
using GerstITS.System.Configurations;
using GerstITS.Web.Api.Swagger; using GerstITS.Web.Api.Swagger;
using Microsoft.Extensions.Configuration;
namespace BakeTronic.Web.Api.Configurations namespace GerstITS.Examples.Api.Configurations;
internal sealed class LicenseConfiguration : ILicense, System.Configurations.IConfiguration
{ {
internal sealed class LicenseConfiguration : ILicense, GerstITS.System.Configurations.IConfiguration #region Constructors
public LicenseConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration)
{ {
#region Constructors var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
public LicenseConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration) Name = configuration.GetValue<string>($"{prefix}:{nameof(Name)}");
{ Url = configuration.GetValue<Uri>($"{prefix}:{nameof(Url)}");
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}"; }
Name = configuration.GetValue<string>($"{prefix}:{nameof(Name)}");
Url = configuration.GetValue<Uri>($"{prefix}:{nameof(Url)}");
}
#endregion #endregion
#region ILicence #region ILicence
public string Name { get; } public string Name { get; }
public Uri Url { get; } public Uri Url { get; }
#endregion #endregion
}
} }

View File

@@ -1,46 +1,44 @@
using System; using System.Diagnostics;
using System.Diagnostics; using GerstITS.Common;
using GerstITS.Examples.Api.Configurations;
using GerstITS.System.Configurations; using GerstITS.System.Configurations;
using GerstITS.Web.Api.Swagger; using GerstITS.Web.Api.Swagger;
using Microsoft.Extensions.Configuration;
namespace BakeTronic.Web.Api.Configurations namespace GerstITS.Examples.Api.Configurations;
internal sealed class SwaggerConfiguration : ISwaggerConfiguration
{ {
internal sealed class SwaggerConfiguration : ISwaggerConfiguration #region Constructors
public SwaggerConfiguration(string parentPrefix,
Microsoft.Extensions.Configuration.IConfiguration configuration)
{ {
#region Constructors var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
public SwaggerConfiguration(string parentPrefix, var currentAssembly = typeof(WebApiConfiguration).Assembly;
Microsoft.Extensions.Configuration.IConfiguration configuration) var fileVersionInfo = FileVersionInfo.GetVersionInfo(currentAssembly.Location);
{
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
var currentAssembly = typeof(WebApiConfiguration).Assembly; Name = fileVersionInfo.ProductName;
var fileVersionInfo = FileVersionInfo.GetVersionInfo(currentAssembly.Location); Company = fileVersionInfo.CompanyName;
SupportEMail = configuration.GetValue<string>($"{prefix}:{nameof(SupportEMail)}");
TermsOfService = configuration.GetValue<Uri>($"{prefix}:{nameof(TermsOfService)}");
Name = fileVersionInfo.ProductName; Release = currentAssembly.GetName().Version;
Company = fileVersionInfo.CompanyName; License = new LicenseConfiguration(prefix, configuration);
SupportEMail = configuration.GetValue<string>($"{prefix}:{nameof(SupportEMail)}"); Securities = new OpenApiSecuritySchemeConfiguration().AsEnumerable()
TermsOfService = configuration.GetValue<Uri>($"{prefix}:{nameof(TermsOfService)}"); .ToList();
Release = currentAssembly.GetName().Version;
License = new LicenseConfiguration(prefix, configuration);
Security = new OpenApiSecuritySchemeConfiguration();
}
#endregion
#region ISwaggerConfiguration
public string Name { get; }
public string Company { get; }
public string SupportEMail { get; }
public Uri TermsOfService { get; }
public Version Release { get; }
public ILicense License { get; }
public IOpenApiSecuritySchemeConfiguration Security { get; }
#endregion
} }
#endregion
#region ISwaggerConfiguration
public string Name { get; }
public string Company { get; }
public string SupportEMail { get; }
public Uri TermsOfService { get; }
public Version Release { get; }
public IEnumerable<IOpenApiSecuritySchemeConfiguration> Securities { get; }
public ILicense License { get; }
#endregion
} }

View File

@@ -1,35 +1,33 @@
using BakeTronic.Web.Api.Configurations; using GerstITS.Authentication.OpenId;
using GerstITS.Authentication.OpenId;
using GerstITS.Data.EntityFramework; using GerstITS.Data.EntityFramework;
using GerstITS.System.Configurations; using GerstITS.System.Configurations;
using GerstITS.Web.Api.Builder; using GerstITS.Web.Api.Builder;
using GerstITS.Web.Api.Swagger; using GerstITS.Web.Api.Swagger;
namespace GerstITS.Examples.Api.Configurations namespace GerstITS.Examples.Api.Configurations;
internal sealed class WebApiConfiguration : GerstITS.System.Configurations.IConfiguration
{ {
internal sealed class WebApiConfiguration : IConfiguration #region Properties
public IServerConfiguration Server { get; }
public IOpenIdConfiguration OpenId { get; }
public ISwaggerConfiguration Swagger { get; set; }
public IEntityFrameworkMigrationConfiguration EntityFrameworkMigration { get; set; }
#endregion
#region Constructors
public WebApiConfiguration(Microsoft.Extensions.Configuration.IConfiguration configuration)
{ {
#region Properties var prefix = this.ToConfigurationPrefix();
public IServerConfiguration Server { get; } EntityFrameworkMigration = new EntityFrameworkMigrationConfiguration(prefix, configuration);
public IOpenIdConfiguration OpenId { get; } //OpenId = new OpenIdConfiguration(prefix, configuration);
public ISwaggerConfiguration Swagger { get; set; } Server = new ServerConfiguration(prefix, configuration);
public IEntityFrameworkMigrationConfiguration EntityFrameworkMigration { get; set; } Swagger = new SwaggerConfiguration(prefix, configuration);
#endregion
#region Constructors
public WebApiConfiguration(Microsoft.Extensions.Configuration.IConfiguration configuration)
{
var prefix = this.ToConfigurationPrefix();
EntityFrameworkMigration = new EntityFrameworkMigrationConfiguration(prefix, configuration);
OpenId = new OpenIdConfiguration(prefix, configuration);
Server = new ServerConfiguration(prefix, configuration);
Swagger = new SwaggerConfiguration(prefix, configuration);
}
#endregion
} }
#endregion
} }

View File

@@ -2,18 +2,21 @@
using GerstITS.Data; using GerstITS.Data;
using GerstITS.Web.Api.ExceptionHandling; using GerstITS.Web.Api.ExceptionHandling;
namespace GerstITS.Examples.Api.ExceptionHandling namespace GerstITS.Examples.Api.ExceptionHandling;
public class EntityNotFoundExceptionTransformation : ExceptionTransformationBase<EntityNotFoundException>
{ {
public class EntityNotFoundExceptionTransformation : ExceptionTransformationBase<EntityNotFoundException> #region Methods
protected override ExceptionTransformationInfo CreateExceptionTransformationInfo(EntityNotFoundException exception, string ticketId)
{ {
protected override ExceptionTransformationInfo CreateExceptionTransformationInfo(EntityNotFoundException exception, string ticketId) return new ExceptionTransformationInfo
{ {
return new ExceptionTransformationInfo StatusCode = HttpStatusCode.NotFound,
{ ReasonPhrase = "Enitity nicht gefunden",
StatusCode = HttpStatusCode.NotFound, Details = exception.Message
ReasonPhrase = "Enitity nicht gefunden", };
Details = exception.Message }
};
} #endregion
} }
}

View File

@@ -2,22 +2,21 @@
using System.Net; using System.Net;
using GerstITS.Web.Api.ExceptionHandling; using GerstITS.Web.Api.ExceptionHandling;
namespace GerstITS.Examples.Api.ExceptionHandling namespace GerstITS.Examples.Api.ExceptionHandling;
{
internal sealed class ValidationExceptionTransformation : ExceptionTransformationBase<ValidationException>
{
#region Methods
protected override ExceptionTransformationInfo CreateExceptionTransformationInfo(ValidationException exception, string ticketId) internal sealed class ValidationExceptionTransformation : ExceptionTransformationBase<ValidationException>
{ {
return new ExceptionTransformationInfo #region Methods
{
StatusCode = HttpStatusCode.BadRequest, protected override ExceptionTransformationInfo CreateExceptionTransformationInfo(ValidationException exception, string ticketId)
ReasonPhrase = "Validierungsfehler", {
Details = exception.Message return new ExceptionTransformationInfo
}; {
} StatusCode = HttpStatusCode.BadRequest,
ReasonPhrase = "Validierungsfehler",
Details = exception.Message
};
}
#endregion #endregion
} }
}

View File

@@ -3,37 +3,36 @@ using GerstITS.Examples.Logic.Example;
using GerstITS.IoC; using GerstITS.IoC;
using GerstITS.System.Json; using GerstITS.System.Json;
namespace GerstITS.Examples.Api.StartupTasks namespace GerstITS.Examples.Api.StartupTasks;
internal class ExampleStartupTask : IStartupTask
{ {
internal class ExampleStartupTask : IStartupTask #region Fields#
private readonly IExampleProvider _provider;
private readonly IJsonConvert _jsonConvert;
#endregion
#region Construtcors
public ExampleStartupTask(IExampleProvider provider,
IJsonConvert jsonConvert)
{ {
#region Fields# _jsonConvert = jsonConvert;
_provider = provider;
private readonly IExampleProvider _provider;
private readonly IJsonConvert _jsonConvert;
#endregion
#region Construtcors
public ExampleStartupTask(IExampleProvider provider,
IJsonConvert jsonConvert)
{
_jsonConvert = jsonConvert;
_provider = provider;
}
#endregion
#region IStartupTask
public StartupPriorities Priority => StartupPriorities.Normal;
public void Execute()
{
Debug.WriteLine($"---> {nameof(ExampleStartupTask)}: {_jsonConvert.Serialize(_provider.GetById(123))}");
}
#endregion
} }
}
#endregion
#region IStartupTask
public StartupPriorities Priority => StartupPriorities.Normal;
public void Execute()
{
Debug.WriteLine($"---> {nameof(ExampleStartupTask)}: {_jsonConvert.Serialize(_provider.GetById(123))}");
}
#endregion
}

View File

@@ -1,12 +1,11 @@
namespace GerstITS.Examples.Api.Versioning namespace GerstITS.Examples.Api.Versioning;
public static class Versions
{ {
public static class Versions #region Versions
{
#region Versions
public const string _1_0 = "1.0"; public const string _1_0 = "1.0";
public const string _1_1 = "1.1"; public const string _1_1 = "1.1";
#endregion #endregion
}
} }

View File

@@ -1,52 +1,52 @@
using GerstITS.Examples.Api.Versioning; using Asp.Versioning;
using GerstITS.Examples.Api.Versioning;
using GerstITS.Examples.Logic.Example; using GerstITS.Examples.Logic.Example;
using GerstITS.Validation; using GerstITS.Validation;
using GerstITS.Web.Api; using GerstITS.Web.Api;
using GerstITS.Web.Api.FluentApi; using GerstITS.Web.Api.FluentApi;
using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc;
namespace GerstITS.Examples.Api.Controllers namespace GerstITS.Examples.Api.Controllers;
/// <summary>
/// Controller is deprecated use newer version.
/// </summary>
[ApiController,
ApiVersion(Versions._1_0, Deprecated = true),
Route(ApplicationEnvironment.WebApi.ControllerRouteTemplate)]
public class ExampleController : FluentApiControllerBase
{ {
/// <summary> #region Fields
/// Controller is deprecated use newer version.
/// </summary>
[ApiController,
ApiVersion(Versions._1_0, Deprecated = true),
Route(ApplicationEnvironment.WebApi.ControllerRouteTemplate)]
public class ExampleController : FluentApiControllerBase
{
#region Fields
private readonly IExampleProvider _provider; private readonly IExampleProvider _provider;
#endregion #endregion
#region Constructors #region Constructors
public ExampleController(IExampleProvider provider, public ExampleController(IExampleProvider provider,
IValidator validator) IValidator validator)
: base(validator) : base(validator)
{ {
_provider = provider; _provider = provider;
}
#endregion
#region Methods
/// <summary>
/// Gets the example data by id.
/// </summary>
/// <param name="id"></param>
/// <returns>Returns Example data.</returns>
[HttpGet,
Route("{id}")]
public IActionResult Get(int id)
{
return Api().Use(id)
.Get(_provider.GetById);
}
#endregion
} }
}
#endregion
#region Methods
/// <summary>
/// Gets the example data by id.
/// </summary>
/// <param name="id"></param>
/// <returns>Returns Example data.</returns>
[HttpGet,
Route("{id}")]
public IActionResult Get(int id)
{
return Api().Use(id)
.Get(_provider.GetById);
}
#endregion
}

View File

@@ -1,52 +1,52 @@
using GerstITS.Examples.Api.Versioning; using Asp.Versioning;
using GerstITS.Examples.Api.Versioning;
using GerstITS.Examples.Logic.Example; using GerstITS.Examples.Logic.Example;
using GerstITS.Validation; using GerstITS.Validation;
using GerstITS.Web.Api; using GerstITS.Web.Api;
using GerstITS.Web.Api.FluentApi; using GerstITS.Web.Api.FluentApi;
using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc;
namespace GerstITS.Examples.Api.Controllers._1._1 namespace GerstITS.Examples.Api.Controllers._1._1;
/// <summary>
/// Is responsible to get employee organization assignment examples.
/// </summary>
[ApiController,
ApiVersion(Versions._1_1),
Route(ApplicationEnvironment.WebApi.ControllerRouteTemplate)]
public class ExampleController : FluentApiControllerBase
{ {
/// <summary> #region Fields
/// Is responsible to get employee organization assignment examples.
/// </summary> private readonly IExampleProvider _provider;
[ApiController,
ApiVersion(Versions._1_1), #endregion
Route(ApplicationEnvironment.WebApi.ControllerRouteTemplate)]
public class ExampleController : FluentApiControllerBase #region Constructors
public ExampleController(IExampleProvider provider,
IValidator validator)
: base(validator)
{ {
#region Fields _provider = provider;
private readonly IExampleProvider _provider;
#endregion
#region Constructors
public ExampleController(IExampleProvider provider,
IValidator validator)
: base(validator)
{
_provider = provider;
}
#endregion
#region Methods
/// <summary>
/// Gets a employee organization assignment by specified id.
/// </summary>
/// <param name="id">Id of the employee organization assignment.</param>
/// <returns>Returns an employee organization assignment</returns>
[HttpGet,
Route("{id}")]
public IActionResult Get(int id)
{
return Api().Use(id)
.Get(_provider.GetById_v1_1);
}
#endregion
} }
}
#endregion
#region Methods
/// <summary>
/// Gets a employee organization assignment by specified id.
/// </summary>
/// <param name="id">Id of the employee organization assignment.</param>
/// <returns>Returns an employee organization assignment</returns>
[HttpGet,
Route("{id}")]
public IActionResult Get(int id)
{
return Api().Use(id)
.Get(_provider.GetById_v1_1);
}
#endregion
}

View File

@@ -0,0 +1,72 @@
<Project Sdk="Microsoft.NET.Sdk.Web">
<PropertyGroup>
<Company>Gerst ITS</Company>
<Authors>Gerst ITS</Authors>
<Copyright>© 2021 Gerst ITS</Copyright>
<Authors>Gerst ITS</Authors>
<Product>Gerst ITS Examples Web Api</Product>
<Description>Exapmle Web Api</Description>
<Version>0.0.0.0</Version>
<AssemblyVersion>0.0.0.0</AssemblyVersion>
<AssemblyInformationalVersion>0.0.0.0</AssemblyInformationalVersion>
<FileVersion>0.0.0.0</FileVersion>
</PropertyGroup>
<PropertyGroup>
<TargetFramework>net7.0</TargetFramework>
<LangVersion>latest</LangVersion>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
<TreatWarningsAsErrors>true</TreatWarningsAsErrors>
<CheckForOverflowUnderflow>true</CheckForOverflowUnderflow>
<WarningsAsErrors />
<NoWarn>1591</NoWarn>
<DocumentationFile>bin\Release\net5.0\GerstITS.Example.Api.xml</DocumentationFile>
<OutputPath></OutputPath>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|AnyCPU'">
<TreatWarningsAsErrors>true</TreatWarningsAsErrors>
<CheckForOverflowUnderflow>true</CheckForOverflowUnderflow>
<WarningsAsErrors />
<NoWarn>1591</NoWarn>
<DocumentationFile>bin\Release\net5.0\GerstITS.Example.Api.xml</DocumentationFile>
<OutputPath></OutputPath>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="GerstITS.Authentication.OpenId" Version="2022.11.5" />
<PackageReference Include="GerstITS.Common" Version="2022.11.5" />
<PackageReference Include="GerstITS.Data" Version="2022.11.5" />
<PackageReference Include="GerstITS.Data.EntityFramework" Version="2022.11.5" />
<PackageReference Include="GerstITS.IoC" Version="2022.11.5" />
<PackageReference Include="GerstITS.IoC.DotNetCore" Version="2022.11.5" />
<PackageReference Include="GerstITS.Job" Version="2022.11.5" />
<PackageReference Include="GerstITS.Job.Scheduling" Version="2022.11.5" />
<PackageReference Include="GerstITS.Logging.Serilog" Version="2022.3.3" />
<PackageReference Include="GerstITS.Mapping.AutoMapper" Version="2022.3.3" />
<PackageReference Include="GerstITS.Search" Version="2022.3.3" />
<PackageReference Include="GerstITS.System" Version="2022.3.3" />
<PackageReference Include="GerstITS.Validation" Version="2022.3.3" />
<PackageReference Include="GerstITS.Web" Version="2022.3.3" />
<PackageReference Include="GerstITS.Web.Api" Version="2022.3.4" />
<PackageReference Include="GerstITS.Web.Api.Swagger" Version="2022.3.4" />
<PackageReference Include="GerstITS.Web.Rest" Version="2022.3.3" />
<PackageReference Include="Microsoft.AspNetCore.Mvc.NewtonsoftJson" Version="6.0.3" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="6.0.3">
<PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference>
<PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="6.0.0" />
<PackageReference Include="Microsoft.Extensions.DependencyInjection.Abstractions" Version="6.0.0" />
<PackageReference Include="Newtonsoft.Json" Version="13.0.1" />
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\GerstITS.Examples.Jobs.SayHelloWorld\GerstITS.Examples.Jobs.SayHelloWorld.csproj" />
<ProjectReference Include="..\GerstITS.Examples.Logic\GerstITS.Examples.Logic.csproj" />
</ItemGroup>
</Project>

View File

@@ -3,7 +3,7 @@
<PropertyGroup> <PropertyGroup>
<Company>Gerst ITS</Company> <Company>Gerst ITS</Company>
<Authors>Gerst ITS</Authors> <Authors>Gerst ITS</Authors>
<Copyright>© 2021 Gerst ITS</Copyright> <Copyright>© 2025 Gerst ITS</Copyright>
<Authors>Gerst ITS</Authors> <Authors>Gerst ITS</Authors>
<Product>Gerst ITS Examples Web Api</Product> <Product>Gerst ITS Examples Web Api</Product>
<Description>Exapmle Web Api</Description> <Description>Exapmle Web Api</Description>
@@ -13,17 +13,12 @@
<FileVersion>0.0.0.0</FileVersion> <FileVersion>0.0.0.0</FileVersion>
</PropertyGroup> </PropertyGroup>
<PropertyGroup>
<TargetFramework>net5.0</TargetFramework>
<LangVersion>latest</LangVersion>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
<TreatWarningsAsErrors>true</TreatWarningsAsErrors> <TreatWarningsAsErrors>true</TreatWarningsAsErrors>
<CheckForOverflowUnderflow>true</CheckForOverflowUnderflow> <CheckForOverflowUnderflow>true</CheckForOverflowUnderflow>
<WarningsAsErrors /> <WarningsAsErrors />
<NoWarn>1591</NoWarn> <NoWarn>1591</NoWarn>
<DocumentationFile>bin\Release\net5.0\GerstITS.Example.Api.xml</DocumentationFile> <DocumentationFile>bin\Release\net8.0\GerstITS.Example.Api.xml</DocumentationFile>
<OutputPath></OutputPath> <OutputPath></OutputPath>
</PropertyGroup> </PropertyGroup>
@@ -32,36 +27,34 @@
<CheckForOverflowUnderflow>true</CheckForOverflowUnderflow> <CheckForOverflowUnderflow>true</CheckForOverflowUnderflow>
<WarningsAsErrors /> <WarningsAsErrors />
<NoWarn>1591</NoWarn> <NoWarn>1591</NoWarn>
<DocumentationFile>bin\Release\net5.0\GerstITS.Example.Api.xml</DocumentationFile> <DocumentationFile>bin\Release\net8.0\GerstITS.Example.Api.xml</DocumentationFile>
<OutputPath></OutputPath> <OutputPath></OutputPath>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="GerstITS.Authentication.OpenId" Version="2021.7.21" /> <PackageReference Include="GerstITS.Authentication.OpenId" />
<PackageReference Include="GerstITS.Common" Version="2021.6.24" /> <PackageReference Include="GerstITS.Common" />
<PackageReference Include="GerstITS.Data" Version="2021.7.12" /> <PackageReference Include="GerstITS.Data" />
<PackageReference Include="GerstITS.Data.EntityFramework" Version="2021.7.23" /> <PackageReference Include="GerstITS.Data.EntityFramework" />
<PackageReference Include="GerstITS.IoC" Version="2021.7.17" /> <PackageReference Include="GerstITS.IoC" />
<PackageReference Include="GerstITS.IoC.DotNetCore" Version="2021.7.21" /> <PackageReference Include="GerstITS.IoC.DotNetCore" />
<PackageReference Include="GerstITS.Job" Version="2021.6.17" /> <PackageReference Include="GerstITS.Job" />
<PackageReference Include="GerstITS.Job.Scheduling" Version="2021.6.17" /> <PackageReference Include="GerstITS.Job.Scheduling" />
<PackageReference Include="GerstITS.Logging.Serilog" Version="2021.6.25" /> <PackageReference Include="GerstITS.Mapping.AutoMapper" />
<PackageReference Include="GerstITS.Mapping.AutoMapper" Version="2021.6.21" /> <PackageReference Include="GerstITS.Search" />
<PackageReference Include="GerstITS.Search" Version="2021.6.17" /> <PackageReference Include="GerstITS.System" />
<PackageReference Include="GerstITS.System" Version="2021.7.20" /> <PackageReference Include="GerstITS.Validation" />
<PackageReference Include="GerstITS.Validation" Version="2021.7.18" /> <PackageReference Include="GerstITS.Web" />
<PackageReference Include="GerstITS.Web" Version="2021.6.17" /> <PackageReference Include="GerstITS.Web.Api" />
<PackageReference Include="GerstITS.Web.Api" Version="2021.7.21" /> <PackageReference Include="GerstITS.Web.Api.Swagger" />
<PackageReference Include="GerstITS.Web.Api.Swagger" Version="2021.7.20" /> <PackageReference Include="GerstITS.Web.Rest" />
<PackageReference Include="GerstITS.Web.Rest" Version="2021.6.17" /> <PackageReference Include="Microsoft.AspNetCore.Mvc.NewtonsoftJson" />
<PackageReference Include="Microsoft.AspNetCore.Mvc.NewtonsoftJson" Version="5.0.8" /> <PackageReference Include="Microsoft.EntityFrameworkCore.Tools">
<PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="5.0.8">
<PrivateAssets>all</PrivateAssets> <PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference> </PackageReference>
<PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="5.0.2" /> <PackageReference Include="Newtonsoft.Json" />
<PackageReference Include="Microsoft.Extensions.DependencyInjection.Abstractions" Version="5.0.0" /> <PackageReference Include="Serilog.AspNetCore" />
<PackageReference Include="Newtonsoft.Json" Version="13.0.1" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
@@ -69,4 +62,8 @@
<ProjectReference Include="..\GerstITS.Examples.Logic\GerstITS.Examples.Logic.csproj" /> <ProjectReference Include="..\GerstITS.Examples.Logic\GerstITS.Examples.Logic.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup>
<Folder Include="wwwroot\" />
</ItemGroup>
</Project> </Project>

View File

@@ -1,22 +1,20 @@
using GerstITS.Examples.Api.Configurations; using GerstITS.Examples.Api.Configurations;
using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.Api namespace GerstITS.Examples.Api;
public sealed partial class Module
{ {
public sealed partial class Module #region Methods
private static void RegisterConfigurations(IServiceCollection container)
{ {
#region Methods container.AddSingleton<WebApiConfiguration>();
private static void RegisterConfigurations(IServiceCollection container) container.AddSingleton(c => c.GetService<WebApiConfiguration>().EntityFrameworkMigration);
{ container.AddSingleton(c => c.GetService<WebApiConfiguration>().OpenId);
container.AddSingleton<WebApiConfiguration>(); container.AddSingleton(c => c.GetService<WebApiConfiguration>().Server);
container.AddSingleton(c => c.GetService<WebApiConfiguration>().Swagger);
container.AddSingleton(c => c.GetService<WebApiConfiguration>().EntityFrameworkMigration);
container.AddSingleton(c => c.GetService<WebApiConfiguration>().OpenId);
container.AddSingleton(c => c.GetService<WebApiConfiguration>().Server);
container.AddSingleton(c => c.GetService<WebApiConfiguration>().Swagger);
}
#endregion
} }
#endregion
} }

View File

@@ -1,18 +1,16 @@
using GerstITS.Examples.Api.ExceptionHandling; using GerstITS.Examples.Api.ExceptionHandling;
using GerstITS.Web.Api.ExceptionHandling.Extensions; using GerstITS.Web.Api.ExceptionHandling.Extensions;
using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.Api namespace GerstITS.Examples.Api;
public sealed partial class Module
{ {
public sealed partial class Module #region Methods
private static void RegisterExceptionHandling(IServiceCollection container)
{ {
#region Methods container.RegisterExceptionTransformationsOf<ValidationExceptionTransformation>();
private static void RegisterExceptionHandling(IServiceCollection container)
{
container.RegisterExceptionTransformationsOf<ValidationExceptionTransformation>();
}
#endregion
} }
#endregion
} }

View File

@@ -1,22 +0,0 @@
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.Api
{
public sealed partial class Module
{
#region Methods
private static void RegisterMvc(IServiceCollection container)
{
//container.AddTransient<IConfigureOptions<MvcOptions>, ApiMvcOptions>();
//container.AddTransient<IConfigureOptions<MvcNewtonsoftJsonOptions>, MvcJsonOptions>();
container.AddMvc()
.AddNewtonsoftJson()
.SetCompatibilityVersion(CompatibilityVersion.Latest);
}
#endregion
}
}

View File

@@ -1,18 +1,16 @@
using GerstITS.Examples.Api.StartupTasks; using GerstITS.Examples.Api.StartupTasks;
using GerstITS.IoC.DotNetCore; using GerstITS.IoC.DotNetCore;
using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.Api namespace GerstITS.Examples.Api;
public sealed partial class Module
{ {
public sealed partial class Module #region Methods
private static void RegisterStartupTasks(IServiceCollection container)
{ {
#region Methods container.RegisterStartupTasksOf<ExampleStartupTask>();
private static void RegisterStartupTasks(IServiceCollection container)
{
container.RegisterStartupTasksOf<ExampleStartupTask>();
}
#endregion
} }
#endregion
} }

View File

@@ -1,20 +1,17 @@
using GerstITS.IoC; using GerstITS.IoC;
using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.Api namespace GerstITS.Examples.Api;
public sealed partial class Module : IIoCModule<IServiceCollection>
{ {
public sealed partial class Module : IIoCModule<IServiceCollection> #region IIoCModule
public void RegisterComponents(IServiceCollection container)
{ {
#region IIoCModule RegisterConfigurations(container);
RegisterExceptionHandling(container);
public void RegisterComponents(IServiceCollection container) RegisterStartupTasks(container);
{
RegisterConfigurations(container);
RegisterExceptionHandling(container);
RegisterMvc(container);
RegisterStartupTasks(container);
}
#endregion
} }
}
#endregion
}

View File

@@ -1,23 +1,42 @@
using GerstITS.Logging.Serilog; using System.Diagnostics;
using GerstITS.Web.Api;
using GerstITS.Web.Api.Hosting; using GerstITS.Web.Api.Hosting;
using GerstITS.Web.Api.Swagger;
using Serilog;
namespace GerstITS.Examples.Api namespace GerstITS.Examples.Api;
public class Program
{ {
public class Program : ProgramBase<Program> #region Methods
public static void Main(string[] args)
{ {
#region Methods HostingStartup.Use(args)
.Host()
public static void Main(string[] args) .UseSerilog((context, configuration) => {
{ configuration.ReadFrom.Configuration(context.Configuration);
BootstrapLogContext.Execute<Program>(_ => Run(args));
} if (Common.ApplicationEnvironment.IsEfCoreActionStarted)
Debug.WriteLine("==========>>>>>>> Do NOT start Application!!!!");
protected override void ConfigureWebHost(IWebHostBuilder webHostBuilder) })
{ .Services()
webHostBuilder.UseLogging() .Build()
.UseStartup<Startup>(); .IfProduction(app => app.UsePreconfiguredHsts())
} .IfDevelopment(app => app.UseDeveloperExceptionPage()
.UsePreconfiguredSwagger())
#endregion .UsePreconfiguredCors()
.UsePreconfiguredForwardedHeaders()
.UsePreconfiguredHttpsRedirection()
.UseAuthentication()
.UseAuthorization()
.UseRouting()
.UseEndpoints(endpoints => endpoints.MapControllers())
.UseRewriteUnknownPathsToIndexSite(ApplicationEnvironment.WebApi.BaseUrl)
.UseSystemIndependentStaticFiles()
.UseSerilogRequestLogging()
.Run();
} }
}
#endregion
}

View File

@@ -14,6 +14,14 @@
"environmentVariables": { "environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development" "ASPNETCORE_ENVIRONMENT": "Development"
} }
},
"GerstITS.Examples.Api": {
"commandName": "Project",
"launchBrowser": false,
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
},
"applicationUrl": "https://localhost:5001;http://localhost:5000"
} }
} }
} }

View File

@@ -1,34 +0,0 @@
using GerstITS.Web.Api;
using GerstITS.Web.Api.Hosting;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Hosting;
namespace GerstITS.Examples.Api
{
public class Startup : BootstrapperStartupBase
{
#region Methods
protected override void ConfigureApplication(IApplicationBuilder applicationBuilder, IWebHostEnvironment webHostEnvironment)
{
if (webHostEnvironment.IsProduction())
applicationBuilder.UsePreconfiguredHsts();
else
applicationBuilder.UseDeveloperExceptionPage()
.UseSwagger();
applicationBuilder.UsePreconfiguredCors()
.UsePreconfiguredForwardedHeaders()
.UsePreconfiguredHttpsRedirection()
.UseAuthentication()
.UseAuthorization()
.UseRouting()
.UseEndpoints(endpoints => endpoints.MapControllers())
.UseRewriteUnknownPathsToIndexSite(ApplicationEnvironment.WebApi.BaseUrl)
.UseSystemIndependentStaticFiles();
}
#endregion
}
}

View File

@@ -9,15 +9,15 @@
"AllowedHosts": "*", "AllowedHosts": "*",
"WebApi": { "WebApi": {
"Swagger": { "Swagger": {
"SupportEMail": "support@baketronic.com", "SupportEMail": "support@example.com",
"TermsOfService": "https://www.baketronic.com/impressum/", "TermsOfService": "https://www.example.com/impressum/",
"Licence": { "License": {
"Name": "MIT", "Name": "MIT",
"Url": "https://opensource.org/licenses/MIT" "Url": "https://opensource.org/licenses/MIT"
} }
}, },
"EntityFrameworkmigration": { "EntityFrameworkmigration": {
"AutoMigrate": true "AutoMigrate": true
}, },
"Server": { "Server": {
"UseCors": true, "UseCors": true,
@@ -64,15 +64,16 @@
} }
} }
}, },
"NotifyOvenJob": { "Jobs": {
"CronExpression": "*/30 * * * * ? *" "SayHelloWorldJob": {
}, "CronExpression": "*/30 * * * * ? *",
"SayHelloWorldJob": { "Name": "Example Job With Specific Name"
"CronExpression": "*/30 * * * * ? *", },
"Name": "Example Job" "SayHelloWorldWithDefaultNameUsageJob": {
"CronExpression": "*/30 * * * * ? *"
}
}, },
"Serilog": { "Serilog": {
"Using": [ "Serilog.Sinks.Console", "Serilog.Sinks.RollingFile" ],
"MinimumLevel": { "MinimumLevel": {
"Default": "Debug", "Default": "Debug",
"Override": { "Override": {
@@ -88,11 +89,9 @@
} }
}, },
{ {
"Name": "RollingFile", "Name": "File",
"Args": { "Args": {
"pathFormat": "bin/Debug/net5.0/Logs/{Date}.log.json", "path": "../Logs/.log",
"formatter": "Serilog.Formatting.Compact.CompactJsonFormatter, Serilog",
"outputTemplate": "{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} [{Level}] [{SourceContext}] [{EventId}] {Message}{NewLine}{Exception}",
"retainedFileCountLimit": 90, "retainedFileCountLimit": 90,
"rollingInterval": "Day", "rollingInterval": "Day",
"shared": true "shared": true

View File

@@ -1,27 +1,15 @@
using GerstITS.Job.Scheduling; using GerstITS.Job.Scheduling;
using GerstITS.System.Configurations;
using Microsoft.Extensions.Configuration;
namespace GerstITS.Examples.Jobs.SayHelloWorld.Configurations namespace GerstITS.Examples.Jobs.SayHelloWorld.Configurations;
public class SayHelloWorldJobConfiguration : JobSchedulingConfigurationBase
{ {
public class SayHelloWorldJobConfiguration : JobSchedulingConfigurationBase #region Constructors
public SayHelloWorldJobConfiguration(Microsoft.Extensions.Configuration.IConfiguration configuration)
: base(configuration)
{ {
#region Properties }
public string Name { get; }
#endregion
#region Constructors
public SayHelloWorldJobConfiguration(Microsoft.Extensions.Configuration.IConfiguration configuration)
: base(configuration)
{
var prefix = this.ToConfigurationPrefix();
Name = configuration.GetValue<string>($"{prefix}:{nameof(Name)}");
}
#endregion #endregion
}
} }

View File

@@ -0,0 +1,15 @@
using GerstITS.Job.Scheduling;
namespace GerstITS.Examples.Jobs.SayHelloWorld.Configurations;
public class SayHelloWorldWithDefaultNameUsageJobConfiguration : JobSchedulingConfigurationBase
{
#region Constructors
public SayHelloWorldWithDefaultNameUsageJobConfiguration(Microsoft.Extensions.Configuration.IConfiguration configuration)
: base(configuration)
{
}
#endregion
}

View File

@@ -3,7 +3,7 @@
<PropertyGroup> <PropertyGroup>
<Company>Gerst ITS</Company> <Company>Gerst ITS</Company>
<Authors>Gerst ITS</Authors> <Authors>Gerst ITS</Authors>
<Copyright>© 2021 Gerst ITS</Copyright> <Copyright>© 2025 Gerst ITS</Copyright>
<Product>Gerst ITS Examples Job</Product> <Product>Gerst ITS Examples Job</Product>
<Description>Exapmle job.</Description> <Description>Exapmle job.</Description>
<Version>0.0.0.0</Version> <Version>0.0.0.0</Version>
@@ -12,11 +12,6 @@
<FileVersion>0.0.0.0</FileVersion> <FileVersion>0.0.0.0</FileVersion>
</PropertyGroup> </PropertyGroup>
<PropertyGroup>
<TargetFramework>net5.0</TargetFramework>
<LangVersion>latest</LangVersion>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
<TreatWarningsAsErrors>true</TreatWarningsAsErrors> <TreatWarningsAsErrors>true</TreatWarningsAsErrors>
<CheckForOverflowUnderflow>true</CheckForOverflowUnderflow> <CheckForOverflowUnderflow>true</CheckForOverflowUnderflow>
@@ -32,18 +27,17 @@
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="GerstITS.Data" Version="2021.7.12" /> <PackageReference Include="GerstITS.Data" />
<PackageReference Include="GerstITS.IoC" Version="2021.7.17" /> <PackageReference Include="GerstITS.IoC" />
<PackageReference Include="GerstITS.IoC.DotNetCore" Version="2021.7.21" /> <PackageReference Include="GerstITS.IoC.DotNetCore" />
<PackageReference Include="GerstITS.Job" Version="2021.6.17" /> <PackageReference Include="GerstITS.Job" />
<PackageReference Include="GerstITS.Job.Scheduling" Version="2021.6.17" /> <PackageReference Include="GerstITS.Job.Scheduling" />
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="5.0.8" /> <PackageReference Include="Microsoft.EntityFrameworkCore" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Compile Update="Module.Jobs.cs"> <ProjectCapability Include="ConfigurableFileNesting" />
<DependentUpon>Module.cs</DependentUpon> <ProjectCapability Include="ConfigurableFileNestingFeatureEnabled" />
</Compile>
</ItemGroup> </ItemGroup>
</Project> </Project>

View File

@@ -1,51 +1,42 @@
using System.Diagnostics; using System.Diagnostics;
using System.Threading;
using GerstITS.Data;
using GerstITS.Examples.Jobs.SayHelloWorld.Configurations; using GerstITS.Examples.Jobs.SayHelloWorld.Configurations;
using GerstITS.Job; using GerstITS.Job;
using GerstITS.System.Environment; using GerstITS.System.Environment;
using Quartz; using Quartz;
namespace GerstITS.Examples.Jobs.SayHelloWorld.Jobs namespace GerstITS.Examples.Jobs.SayHelloWorld.Jobs;
[DisallowConcurrentExecution]
public class SayHelloWorldJob : JobBase
{ {
[DisallowConcurrentExecution] #region Fields
public class SayHelloWorldJob : JobBase
private readonly SayHelloWorldJobConfiguration _configuration;
private readonly Stopwatch _stopWatch;
#endregion
#region Cosntructors
public SayHelloWorldJob(SayHelloWorldJobConfiguration configuration,
ISystemClock systemClock)
{ {
#region Fields _configuration = configuration;
_stopWatch = new Stopwatch();
private readonly SayHelloWorldJobConfiguration _configuration;
private readonly Stopwatch _stopWatch;
private readonly IRepository _repository;
private readonly ISystemClock _systemClock;
#endregion
#region Cosntructors
public SayHelloWorldJob(SayHelloWorldJobConfiguration configuration,
IRepository repository,
ISystemClock systemClock)
{
_systemClock = systemClock;
_repository = repository;
_configuration = configuration;
_stopWatch = new Stopwatch();
}
#endregion
#region Methods
protected override void Execute()
{
_stopWatch.Restart();
Thread.Sleep(4000);
var now = _systemClock.UtcNow;
_stopWatch.Stop();
Debug.WriteLine($"---> Say hello to world from {_configuration.Name}, Duration: {_stopWatch.ElapsedMilliseconds / 1000}s");
}
#endregion
} }
#endregion
#region Methods
protected override void Execute()
{
_stopWatch.Restart();
Thread.Sleep(4000);
_stopWatch.Stop();
Debug.WriteLine($"---> Say hello to world from {_configuration.Name}, Duration: {_stopWatch.ElapsedMilliseconds / 1000}s");
}
#endregion
} }

View File

@@ -0,0 +1,40 @@
using System.Diagnostics;
using GerstITS.Examples.Jobs.SayHelloWorld.Configurations;
using GerstITS.Job;
using Quartz;
namespace GerstITS.Examples.Jobs.SayHelloWorld.Jobs;
[DisallowConcurrentExecution]
public class SayHelloWorldWithDefaultNameUsageJob : JobBase
{
#region Fields
private readonly SayHelloWorldWithDefaultNameUsageJobConfiguration _configuration;
private readonly Stopwatch _stopWatch;
#endregion
#region Cosntructors
public SayHelloWorldWithDefaultNameUsageJob(SayHelloWorldWithDefaultNameUsageJobConfiguration configuration)
{
_configuration = configuration;
_stopWatch = new Stopwatch();
}
#endregion
#region Methods
protected override void Execute()
{
_stopWatch.Restart();
Thread.Sleep(4000);
_stopWatch.Stop();
Debug.WriteLine($"---> Say hello to world from {_configuration.Name}, Duration: {_stopWatch.ElapsedMilliseconds / 1000}s");
}
#endregion
}

View File

@@ -4,17 +4,16 @@ using GerstITS.IoC;
using GerstITS.Job.Scheduling; using GerstITS.Job.Scheduling;
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.Jobs.SayHelloWorld namespace GerstITS.Examples.Jobs.SayHelloWorld;
{
public sealed class Module : IIoCModule<IServiceCollection>
{
#region IIoCModule
public void RegisterComponents(IServiceCollection container) public sealed class Module : IIoCModule<IServiceCollection>
{ {
container.RegisterJob<SayHelloWorldJob, SayHelloWorldJobConfiguration>(); #region IIoCModule
}
public void RegisterComponents(IServiceCollection container)
{
container.RegisterJob<SayHelloWorldJob, SayHelloWorldJobConfiguration>();
}
#endregion #endregion
} }
}

View File

@@ -1,13 +1,12 @@
namespace GerstITS.Examples.Logic.Example namespace GerstITS.Examples.Logic.Example;
{
public class Example
{
#region Properties
public string FirstName { get; set; } public class Example
public string LastName { get; set; } {
public string Description { get; set; } #region Properties
public string FirstName { get; set; }
public string LastName { get; set; }
public string Description { get; set; }
#endregion #endregion
}
} }

View File

@@ -1,8 +1,7 @@
namespace GerstITS.Examples.Logic.Example namespace GerstITS.Examples.Logic.Example;
public interface IExampleProvider
{ {
public interface IExampleProvider Example GetById(int id);
{ Example GetById_v1_1(int id);
Example GetById(int id); }
Example GetById_v1_1(int id);
}
}

View File

@@ -1,51 +1,50 @@
using AutoMapper; using AutoMapper;
using GerstITS.Data; using GerstITS.Data;
namespace GerstITS.Examples.Logic.Example namespace GerstITS.Examples.Logic.Example;
internal sealed class ExampleProvider : IExampleProvider
{ {
internal sealed class ExampleProvider : IExampleProvider #region Fields
private readonly IMapper _mapper;
#endregion
#region Constructors
public ExampleProvider(IMapper mapper)
{ {
#region Fields _mapper = mapper;
private readonly IMapper _mapper;
#endregion
#region Constructors
public ExampleProvider(IMapper mapper)
{
_mapper = mapper;
}
#endregion
#region IExampleProvider
public Example GetById(int id)
{
ThrowsAnExceptionIfEntityIsNotFound(id);
return _mapper.Map<Example>(id);
}
public Example GetById_v1_1(int id)
{
ThrowsAnExceptionIfEntityIsNotFound(id);
return _mapper.Map<Example>(id);
}
#endregion
#region Methods
private static void ThrowsAnExceptionIfEntityIsNotFound(int id)
{
if (id % 2 == 0)
throw new EntityNotFoundException($"Example mit der Id '{id}' nicht gefunden.");
}
#endregion
} }
#endregion
#region IExampleProvider
public Example GetById(int id)
{
ThrowsAnExceptionIfEntityIsNotFound(id);
return _mapper.Map<Example>(id);
}
public Example GetById_v1_1(int id)
{
ThrowsAnExceptionIfEntityIsNotFound(id);
return _mapper.Map<Example>(id);
}
#endregion
#region Methods
private static void ThrowsAnExceptionIfEntityIsNotFound(int id)
{
if (id % 2 == 0)
throw new EntityNotFoundException($"Example mit der Id '{id}' nicht gefunden.");
}
#endregion
} }

View File

@@ -1,19 +1,18 @@
using AutoMapper; using AutoMapper;
namespace GerstITS.Examples.Logic.Example namespace GerstITS.Examples.Logic.Example;
internal sealed class IntegerMapping : Profile
{ {
internal sealed class IntegerMapping : Profile #region Construtcors
public IntegerMapping()
{ {
#region Construtcors CreateMap<int, Example>()
.ForMember(x => x.FirstName, m => m.MapFrom((s, _) => $"First Name {s}"))
public IntegerMapping() .ForMember(x => x.LastName, m => m.MapFrom((s, _) => $"Last Name {s}"))
{ .ForMember(x => x.Description, m => m.MapFrom((s, _) => $"Useful description for id '{s}'"));
CreateMap<int, Example>()
.ForMember(x => x.FirstName, m => m.MapFrom((s, _) => $"First Name {s}"))
.ForMember(x => x.LastName, m => m.MapFrom((s, _) => $"Last Name {s}"))
.ForMember(x => x.Description, m => m.MapFrom((s, _) => $"Useful description for id '{s}'"));
}
#endregion
} }
}
#endregion
}

View File

@@ -3,7 +3,7 @@
<PropertyGroup> <PropertyGroup>
<Company>Gerst ITS</Company> <Company>Gerst ITS</Company>
<Authors>Gerst ITS</Authors> <Authors>Gerst ITS</Authors>
<Copyright>© 2021 Gerst ITS</Copyright> <Copyright>© 2025 Gerst ITS</Copyright>
<Product>Gerst ITS Examples logic</Product> <Product>Gerst ITS Examples logic</Product>
<Description>Exapmle Logic.</Description> <Description>Exapmle Logic.</Description>
<Version>0.0.0.0</Version> <Version>0.0.0.0</Version>
@@ -12,11 +12,6 @@
<FileVersion>0.0.0.0</FileVersion> <FileVersion>0.0.0.0</FileVersion>
</PropertyGroup> </PropertyGroup>
<PropertyGroup>
<TargetFramework>net5.0</TargetFramework>
<LangVersion>latest</LangVersion>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
<TreatWarningsAsErrors>true</TreatWarningsAsErrors> <TreatWarningsAsErrors>true</TreatWarningsAsErrors>
<CheckForOverflowUnderflow>true</CheckForOverflowUnderflow> <CheckForOverflowUnderflow>true</CheckForOverflowUnderflow>
@@ -32,24 +27,18 @@
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="AutoMapper" Version="10.1.1" /> <PackageReference Include="GerstITS.Data" />
<PackageReference Include="FluentValidation" Version="10.3.0" /> <PackageReference Include="GerstITS.IoC" />
<PackageReference Include="GerstITS.Data" Version="2021.7.12" /> <PackageReference Include="GerstITS.IoC.DotNetCore" />
<PackageReference Include="GerstITS.IoC" Version="2021.7.17" /> <PackageReference Include="GerstITS.Mapping.AutoMapper" />
<PackageReference Include="GerstITS.IoC.DotNetCore" Version="2021.7.21" /> <PackageReference Include="GerstITS.Search" />
<PackageReference Include="GerstITS.Mapping.AutoMapper" Version="2021.6.21" /> <PackageReference Include="GerstITS.Validation" />
<PackageReference Include="GerstITS.Search" Version="2021.6.17" /> <PackageReference Include="GerstITS.Web.Api" />
<PackageReference Include="GerstITS.Validation" Version="2021.7.18" />
<PackageReference Include="GerstITS.Web.Api" Version="2021.7.21" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Compile Update="Module.Example.cs"> <ProjectCapability Include="ConfigurableFileNesting" />
<DependentUpon>Module.cs</DependentUpon> <ProjectCapability Include="ConfigurableFileNestingFeatureEnabled" />
</Compile>
<Compile Update="Module.Shared.cs">
<DependentUpon>Module.cs</DependentUpon>
</Compile>
</ItemGroup> </ItemGroup>
</Project> </Project>

View File

@@ -2,19 +2,18 @@
using GerstITS.Mapping.AutoMapper; using GerstITS.Mapping.AutoMapper;
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.Logic namespace GerstITS.Examples.Logic;
public sealed partial class Module
{ {
public sealed partial class Module #region Methods
private static void RegisterExample(IServiceCollection container)
{ {
#region Methods container.RegisterMappingsOf<IExampleProvider>();
private static void RegisterExample(IServiceCollection container) container.AddScoped<IExampleProvider, ExampleProvider>();
{ }
container.RegisterMappingsOf<IExampleProvider>();
container.AddScoped<IExampleProvider, ExampleProvider>(); #endregion
}
#endregion
}
} }

View File

@@ -4,19 +4,18 @@ using GerstITS.Search;
using GerstITS.Validation; using GerstITS.Validation;
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.Logic namespace GerstITS.Examples.Logic;
public sealed partial class Module
{ {
public sealed partial class Module #region Methods
private static void RegisterShared(IServiceCollection container)
{ {
#region Methods container.RegisterValidationRulesOf<IdValidationRule>();
private static void RegisterShared(IServiceCollection container) container.AddScoped<ISortingProvider, SortingProvider>();
{ }
container.RegisterValidationRulesOf<IdValidationRule>();
container.AddScoped<ISortingProvider, SortingProvider>(); #endregion
}
#endregion
}
} }

View File

@@ -1,18 +1,17 @@
using GerstITS.IoC; using GerstITS.IoC;
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.Logic namespace GerstITS.Examples.Logic;
{
public sealed partial class Module : IIoCModule<IServiceCollection>
{
#region IIoCModule
public void RegisterComponents(IServiceCollection container) public sealed partial class Module : IIoCModule<IServiceCollection>
{ {
RegisterExample(container); #region IIoCModule
RegisterShared(container);
} public void RegisterComponents(IServiceCollection container)
{
RegisterExample(container);
RegisterShared(container);
}
#endregion #endregion
} }
}

View File

@@ -1,31 +1,28 @@
using System; using System.Linq.Expressions;
using System.Linq;
using System.Linq.Expressions;
using GerstITS.Common; using GerstITS.Common;
using GerstITS.Data; using GerstITS.Data;
namespace GerstITS.Examples.Logic.Shared namespace GerstITS.Examples.Logic.Shared;
internal static class ISearchEngineExtensions
{ {
internal static class ISearchEngineExtensions #region Methods
public static TEntity QueryBy<TEntity>(this IReadOnlyRepository repository, Expression<Func<TEntity, bool>> condition)
where TEntity : IEntity
{ {
#region Methods return repository.Query<TEntity>()
.Where(condition)
public static TEntity QueryBy<TEntity>(this IReadOnlyRepository repository, Expression<Func<TEntity, bool>> condition) .FirstOrDefault();
where TEntity : IEntity
{
return repository.Query<TEntity>()
.Where(condition)
.FirstOrDefault();
}
public static TModel ThrowsAnExceptionIfNotFound<TModel, TKey>(this TModel model, TKey id)
{
if (model.IsNull())
throw new EntityNotFoundException($"{typeof(TModel).Name} with id '{id}' not found.");
return model;
}
#endregion
} }
public static TModel ThrowsAnExceptionIfNotFound<TModel, TKey>(this TModel model, TKey id)
{
if (model.IsNull())
throw new EntityNotFoundException($"{typeof(TModel).Name} with id '{id}' not found.");
return model;
}
#endregion
} }

View File

@@ -1,6 +1,5 @@
namespace GerstITS.Examples.Logic.Shared.Search.Sorting namespace GerstITS.Examples.Logic.Shared.Search.Sorting;
internal interface ISortable
{ {
internal interface ISortable }
{
}
}

View File

@@ -1,50 +1,47 @@
using System; using System.Linq.Expressions;
using System.Linq;
using System.Linq.Expressions;
using System.Reflection; using System.Reflection;
using GerstITS.Common; using GerstITS.Common;
using GerstITS.Search; using GerstITS.Search;
namespace GerstITS.Examples.Logic.Shared.Search.Sorting namespace GerstITS.Examples.Logic.Shared.Search.Sorting;
internal class SortingProvider : ISortingProvider
{ {
internal class SortingProvider : ISortingProvider #region ISortingProvider
public bool CanSort<TItem>(IQueryable<TItem> query)
{ {
#region ISortingProvider return typeof(TItem).IsAssignableTo(typeof(ISortable));
public bool CanSort<TItem>(IQueryable<TItem> query)
{
return typeof(TItem).IsAssignableTo(typeof(ISortable));
}
public IQueryable<TItem> Sort<TItem>(IQueryable<TItem> query, ISorting sorting)
{
var propertyInfo = typeof(TItem).GetProperties()
.SingleOrDefault(i => string.Equals(i.Name, sorting.SortBy, StringComparison.InvariantCultureIgnoreCase));
if (!CanSort(query) || propertyInfo.IsNull())
return query;
var sortExpression = CreateSortExpression<TItem>(propertyInfo);
return (sorting.SortDirection == SortingDirections.Ascending
? query.OrderBy(sortExpression)
: query.OrderByDescending(sortExpression))
.AsQueryable();
}
#endregion
#region Methods
private static Expression<Func<TItem, object>> CreateSortExpression<TItem>(MemberInfo propertyInfo)
{
var parameterExpression = Expression.Parameter(typeof(TItem), "x");
var propertyExpression = Expression.Property(parameterExpression, propertyInfo.Name);
var convertExpression = Expression.Convert(propertyExpression, typeof(object));
return Expression.Lambda<Func<TItem, object>>(convertExpression, parameterExpression);
}
#endregion
} }
}
public IQueryable<TItem> Sort<TItem>(IQueryable<TItem> query, ISorting sorting)
{
var propertyInfo = typeof(TItem).GetProperties()
.SingleOrDefault(i => string.Equals(i.Name, sorting.SortBy, StringComparison.InvariantCultureIgnoreCase));
if (!CanSort(query) || propertyInfo.IsNull())
return query;
var sortExpression = CreateSortExpression<TItem>(propertyInfo);
return (sorting.SortDirection == SortingDirections.Ascending
? query.OrderBy(sortExpression)
: query.OrderByDescending(sortExpression))
.AsQueryable();
}
#endregion
#region Methods
private static Expression<Func<TItem, object>> CreateSortExpression<TItem>(MemberInfo propertyInfo)
{
var parameterExpression = Expression.Parameter(typeof(TItem), "x");
var propertyExpression = Expression.Property(parameterExpression, propertyInfo.Name);
var convertExpression = Expression.Convert(propertyExpression, typeof(object));
return Expression.Lambda<Func<TItem, object>>(convertExpression, parameterExpression);
}
#endregion
}

View File

@@ -1,19 +1,18 @@
using FluentValidation; using FluentValidation;
using GerstITS.Validation; using GerstITS.Validation;
namespace GerstITS.Examples.Logic.Shared.Validation namespace GerstITS.Examples.Logic.Shared.Validation;
{
internal sealed class IdValidationRule : ValidationRuleBase<int>
{
#region Constructors
public IdValidationRule()
{
RuleFor(x => x)
.GreaterThan(0)
.OverridePropertyName("id");
}
#endregion internal sealed class IdValidationRule : ValidationRuleBase<int>
} {
} #region Constructors
public IdValidationRule()
{
RuleFor(x => x)
.GreaterThan(0)
.OverridePropertyName("id");
}
#endregion
}

View File

@@ -3,7 +3,7 @@
<PropertyGroup> <PropertyGroup>
<Company>Gerst ITS</Company> <Company>Gerst ITS</Company>
<Authors>Gerst ITS</Authors> <Authors>Gerst ITS</Authors>
<Copyright>© 2021 Gerst ITS</Copyright> <Copyright>© 2025 Gerst ITS</Copyright>
<Product>Gerst ITS Examples Web Api client console application</Product> <Product>Gerst ITS Examples Web Api client console application</Product>
<Description>Exapmle Web Api client console application.</Description> <Description>Exapmle Web Api client console application.</Description>
<Version>0.0.0.0</Version> <Version>0.0.0.0</Version>
@@ -13,8 +13,6 @@
</PropertyGroup> </PropertyGroup>
<PropertyGroup> <PropertyGroup>
<TargetFramework>net5.0</TargetFramework>
<LangVersion>latest</LangVersion>
<OutputType>Exe</OutputType> <OutputType>Exe</OutputType>
</PropertyGroup> </PropertyGroup>
@@ -43,15 +41,16 @@
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="GerstITS.Common" Version="2021.6.24" /> <PackageReference Include="GerstITS.Common" />
<PackageReference Include="GerstITS.IoC" Version="2021.7.17" /> <PackageReference Include="GerstITS.IoC" />
<PackageReference Include="GerstITS.IoC.DotNetCore" Version="2021.7.21" /> <PackageReference Include="GerstITS.IoC.DotNetCore" />
<PackageReference Include="GerstITS.System" Version="2021.7.20" /> <PackageReference Include="GerstITS.System" />
<PackageReference Include="GerstITS.Web" Version="2021.6.17" /> <PackageReference Include="GerstITS.Web" />
<PackageReference Include="GerstITS.Web.Rest" Version="2021.6.17" /> <PackageReference Include="GerstITS.Web.Rest" />
<PackageReference Include="Microsoft.Extensions.Configuration" Version="5.0.0" /> <PackageReference Include="Hocon.Extensions.Configuration" />
<PackageReference Include="Microsoft.Extensions.Configuration.FileExtensions" Version="5.0.0" /> <PackageReference Include="Microsoft.Extensions.Configuration.FileExtensions" />
<PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="5.0.0" /> <PackageReference Include="Microsoft.Extensions.Configuration.Json" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>

View File

@@ -1,25 +1,23 @@
using System; using GerstITS.Examples.WebClient.Console.Tests;
using GerstITS.Examples.WebClient.Console.Tests;
using GerstITS.IoC; using GerstITS.IoC;
using GerstITS.IoC.DotNetCore; using GerstITS.IoC.DotNetCore;
using Microsoft.Extensions.Configuration; using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.WebClient.Console namespace GerstITS.Examples.WebClient.Console;
public class Module : IIoCModule<IServiceCollection>
{ {
public class Module : IIoCModule<IServiceCollection> #region IIoCModule
public void RegisterComponents(IServiceCollection container)
{ {
#region IIoCModule container.AddTransient<IApplicationStart, TestRunner>();
public void RegisterComponents(IServiceCollection container) container.AddTransient<IConfiguration>(c => new ConfigurationBuilder().SetBasePath(AppDomain.CurrentDomain.BaseDirectory)
{ .AddJsonFile("appsettings.json", false, true)
container.AddTransient<IApplicationStart, TestRunner>(); .Build());
container.AddTransient<IConfiguration>(c => new ConfigurationBuilder().SetBasePath(AppDomain.CurrentDomain.BaseDirectory)
.AddJsonFile("appsettings.json", false, true)
.Build());
}
#endregion
} }
#endregion
} }

View File

@@ -1,31 +1,30 @@
using GerstITS.IoC.DotNetCore; using GerstITS.IoC.DotNetCore;
namespace GerstITS.Examples.WebClient.Console namespace GerstITS.Examples.WebClient.Console;
internal class Program
{ {
internal class Program #region Fields
private static readonly DotNetCoreApplicationBootstrapper _bootstrapper;
#endregion
#region Constructors
static Program()
{ {
#region Fields _bootstrapper = new DotNetCoreApplicationBootstrapper();
private static readonly DotNetCoreApplicationBootstrapper _bootstrapper;
#endregion
#region Constructors
static Program()
{
_bootstrapper = new DotNetCoreApplicationBootstrapper();
}
#endregion
#region Methods
private static void Main(string[] args)
{
_bootstrapper.Run();
}
#endregion
} }
}
#endregion
#region Methods
private static void Main(string[] args)
{
_bootstrapper.Run();
}
#endregion
}

View File

@@ -1,51 +1,48 @@
using System; using GerstITS.Examples.WebClients.Examples.Api;
using System.Linq;
using GerstITS.Examples.WebClients.Examples.Api;
using GerstITS.IoC.DotNetCore; using GerstITS.IoC.DotNetCore;
using GerstITS.Web.WebClients; using GerstITS.Web.WebClients;
namespace GerstITS.Examples.WebClient.Console.Tests namespace GerstITS.Examples.WebClient.Console.Tests;
internal sealed class TestRunner : IApplicationStart
{ {
internal sealed class TestRunner : IApplicationStart #region Fields
private readonly IWebClient _webClient;
#endregion
#region Construtors
public TestRunner(IWebClient webClient)
{ {
#region Fields _webClient = webClient;
}
private readonly IWebClient _webClient;
#endregion
#region Construtors
public TestRunner(IWebClient webClient)
{
_webClient = webClient;
}
#endregion #endregion
#region ITestRunner #region ITestRunner
public void Run() public void Run()
{ {
var result1 = _webClient.Request<ICountry>() var result1 = _webClient.Request<ICountry>()
.Execute(c => c.Search(new SearchCriteria .Execute(c => c.Search(new SearchCriteria
{ SortBy = nameof(Country.Name), SortDirection = SortingDirections.Descending, Skip = 5, Take = 5})); { SortBy = nameof(Country.Name), SortDirection = SortingDirections.Descending, Skip = 5, Take = 5}));
var result2 = _webClient.Request<ICountry>() var result2 = _webClient.Request<ICountry>()
.Execute(c => c.Get(result1.Value.Result.First().Id)); .Execute(c => c.Get(result1.Value.Result.First().Id));
var test3 = _webClient.Request<ICountry>() var test3 = _webClient.Request<ICountry>()
.Execute(c => c.Create(new Country {Name = $"Country-{Guid.NewGuid()}"})); .Execute(c => c.Create(new Country {Name = $"Country-{Guid.NewGuid()}"}));
test3.Value.Name += "_Renamed"; test3.Value.Name += "_Renamed";
var test4 = _webClient.Request<ICountry>() var test4 = _webClient.Request<ICountry>()
.Execute(c => c.Update(test3.Value)); .Execute(c => c.Update(test3.Value));
var test5 = _webClient.Request<ICountry>() var test5 = _webClient.Request<ICountry>()
.Execute(c => c.Delete(test3.Value.Id)); .Execute(c => c.Delete(test3.Value.Id));
} }
#endregion #endregion
}
} }

View File

@@ -1,7 +1,7 @@
Microsoft Visual Studio Solution File, Format Version 12.00 Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio Version 16 # Visual Studio Version 18
VisualStudioVersion = 16.0.31321.278 VisualStudioVersion = 18.0.11217.181 d18.0
MinimumVisualStudioVersion = 10.0.40219.1 MinimumVisualStudioVersion = 10.0.40219.1
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "GerstITS.Examples.Api", "GerstITS.Examples.Api\GerstITS.Examples.Api.csproj", "{417B5C77-05BF-4562-9A1A-AEE0531B59C1}" Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "GerstITS.Examples.Api", "GerstITS.Examples.Api\GerstITS.Examples.Api.csproj", "{417B5C77-05BF-4562-9A1A-AEE0531B59C1}"
EndProject EndProject

View File

@@ -1,3 +1,5 @@
<wpf:ResourceDictionary xml:space="preserve" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:s="clr-namespace:System;assembly=mscorlib" xmlns:ss="urn:shemas-jetbrains-com:settings-storage-xaml" xmlns:wpf="http://schemas.microsoft.com/winfx/2006/xaml/presentation"> <wpf:ResourceDictionary xml:space="preserve" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:s="clr-namespace:System;assembly=mscorlib" xmlns:ss="urn:shemas-jetbrains-com:settings-storage-xaml" xmlns:wpf="http://schemas.microsoft.com/winfx/2006/xaml/presentation">
<s:String x:Key="/Default/CodeStyle/Naming/CSharpNaming/PredefinedNamingRules/=PrivateStaticReadonly/@EntryIndexedValue">&lt;Policy Inspect="True" Prefix="_" Suffix="" Style="aaBb" /&gt;</s:String> <s:String x:Key="/Default/CodeStyle/Naming/CSharpNaming/PredefinedNamingRules/=PrivateStaticReadonly/@EntryIndexedValue">&lt;Policy Inspect="True" Prefix="_" Suffix="" Style="aaBb" /&gt;</s:String>
<s:String x:Key="/Default/CodeStyle/Naming/CSharpNaming/UserRules/=15b5b1f1_002D457c_002D4ca6_002Db278_002D5615aedc07d3/@EntryIndexedValue">&lt;Policy&gt;&lt;Descriptor Staticness="Static" AccessRightKinds="Private" Description="Static readonly fields (private)"&gt;&lt;ElementKinds&gt;&lt;Kind Name="READONLY_FIELD" /&gt;&lt;/ElementKinds&gt;&lt;/Descriptor&gt;&lt;Policy Inspect="True" WarnAboutPrefixesAndSuffixes="False" Prefix="_" Suffix="" Style="aaBb" /&gt;&lt;/Policy&gt;</s:String>
<s:Boolean x:Key="/Default/Environment/SettingsMigration/IsMigratorApplied/=JetBrains_002EReSharper_002EPsi_002ECSharp_002ECodeStyle_002ESettingsUpgrade_002EPredefinedNamingRulesToUserRulesUpgrade/@EntryIndexedValue">True</s:Boolean>
<s:Boolean x:Key="/Default/UserDictionary/Words/=Gerst/@EntryIndexedValue">True</s:Boolean></wpf:ResourceDictionary> <s:Boolean x:Key="/Default/UserDictionary/Words/=Gerst/@EntryIndexedValue">True</s:Boolean></wpf:ResourceDictionary>

View File

@@ -1,17 +1,16 @@
using GerstITS.Web.Rest.WebClients; using GerstITS.Web.Rest.WebClients;
using Microsoft.Extensions.Configuration; using Microsoft.Extensions.Configuration;
namespace GerstITS.Examples.WebClients.Examples.Api.Configurations namespace GerstITS.Examples.WebClients.Examples.Api.Configurations;
{
internal class ExampleApiClientConfiguration : RestWebServiceConfigurationBase
{
#region Constructors
public ExampleApiClientConfiguration(IConfiguration configuration) internal class ExampleApiClientConfiguration : RestWebServiceConfigurationBase
: base(configuration) {
{ #region Constructors
}
public ExampleApiClientConfiguration(IConfiguration configuration)
: base(configuration)
{
}
#endregion #endregion
} }
}

View File

@@ -1,27 +1,26 @@
using GerstITS.Web.WebClients; using GerstITS.Web.WebClients;
namespace GerstITS.Examples.WebClients.Examples.Api namespace GerstITS.Examples.WebClients.Examples.Api;
public interface ICountry : IWebService
{ {
public interface ICountry : IWebService [WebMethod(WebMethods.Get),
{ ResourceUrl("Country/{id}")]
[WebMethod(WebMethods.Get), Country Get(int id);
ResourceUrl("Country/{id}")]
Country Get(int id);
[WebMethod(WebMethods.Get), [WebMethod(WebMethods.Get),
ResourceUrl("Country/Search")] ResourceUrl("Country/Search")]
SearchResult<Country> Search(SearchCriteria criteria); SearchResult<Country> Search(SearchCriteria criteria);
[WebMethod(WebMethods.Post), [WebMethod(WebMethods.Post),
ResourceUrl("Country")] ResourceUrl("Country")]
Country Create(Country model); Country Create(Country model);
[WebMethod(WebMethods.Put), [WebMethod(WebMethods.Put),
ResourceUrl("Country")] ResourceUrl("Country")]
void Update(Country model); void Update(Country model);
[WebMethod(WebMethods.Delete), [WebMethod(WebMethods.Delete),
ResourceUrl("Country/{id}")] ResourceUrl("Country/{id}")]
void Delete(int id); void Delete(int id);
}
} }

View File

@@ -1,12 +1,11 @@
namespace GerstITS.Examples.WebClients.Examples.Api namespace GerstITS.Examples.WebClients.Examples.Api;
public class Country
{ {
public class Country #region Properties
{
#region Properties
public int Id { get; set; } public int Id { get; set; }
public string Name { get; set; } public string Name { get; set; }
#endregion #endregion
}
} }

View File

@@ -1,18 +1,17 @@
namespace GerstITS.Examples.WebClients.Examples.Api namespace GerstITS.Examples.WebClients.Examples.Api;
public class SearchCriteria
{ {
public class SearchCriteria #region Properties
{
#region Properties
internal int Id { get; set; } internal int Id { get; set; }
public string Name { get; set; } public string Name { get; set; }
public int? Skip { get; set; } public int? Skip { get; set; }
public int? Take { get; set; } public int? Take { get; set; }
public string SortBy { get; set; } public string SortBy { get; set; }
public SortingDirections SortDirection { get; set; } public SortingDirections SortDirection { get; set; }
#endregion #endregion
}
} }

View File

@@ -1,24 +1,20 @@
using System; namespace GerstITS.Examples.WebClients.Examples.Api;
using System.Collections.Generic;
namespace GerstITS.Examples.WebClients.Examples.Api public class SearchResult<TItem>
{ {
public class SearchResult<TItem> #region Properties
public int TotalCount { get; set; }
public IEnumerable<TItem> Result { get; set; }
#endregion
#region Constructors
public SearchResult()
{ {
#region Properties Result = Array.Empty<TItem>();
public int TotalCount { get; set; }
public IEnumerable<TItem> Result { get; set; }
#endregion
#region Constructors
public SearchResult()
{
Result = Array.Empty<TItem>();
}
#endregion
} }
#endregion
} }

View File

@@ -1,8 +1,7 @@
namespace GerstITS.Examples.WebClients.Examples.Api namespace GerstITS.Examples.WebClients.Examples.Api;
public enum SortingDirections
{ {
public enum SortingDirections Ascending = 0,
{ Descending
Ascending = 0,
Descending
}
} }

View File

@@ -1,25 +1,23 @@
using System; using GerstITS.Examples.WebClients.Examples.Api.Configurations;
using GerstITS.Examples.WebClients.Examples.Api.Configurations;
using GerstITS.Web.Rest.WebClients; using GerstITS.Web.Rest.WebClients;
namespace GerstITS.Examples.WebClients.Examples.Api.CreationRules namespace GerstITS.Examples.WebClients.Examples.Api.CreationRules;
internal sealed class ExampleApiClientCreatingRule : RestApiClientCreationRuleBase<ExampleApiClientConfiguration>
{ {
internal sealed class ExampleApiClientCreatingRule : RestApiClientCreationRuleBase<ExampleApiClientConfiguration> #region Properties
protected override Type[] SupportedTypes => new[] { typeof(ICountry) };
#endregion
#region Constructors
public ExampleApiClientCreatingRule(ExampleApiClientConfiguration configuration,
Func<IRestWebServiceConfiguration, IRestWebServiceClient> restWebServiceClientFactory)
: base(configuration, restWebServiceClientFactory)
{ {
#region Properties }
protected override Type[] SupportedTypes => new[] { typeof(ICountry) };
#endregion
#region Constructors
public ExampleApiClientCreatingRule(ExampleApiClientConfiguration configuration,
Func<IRestWebServiceConfiguration, IRestWebServiceClient> restWebServiceClientFactory)
: base(configuration, restWebServiceClientFactory)
{
}
#endregion #endregion
}
} }

View File

@@ -3,7 +3,7 @@
<PropertyGroup> <PropertyGroup>
<Company>Gerst ITS</Company> <Company>Gerst ITS</Company>
<Authors>Gerst ITS</Authors> <Authors>Gerst ITS</Authors>
<Copyright>© 2021 Gerst ITS</Copyright> <Copyright>© 2025 Gerst ITS</Copyright>
<Product>Gerst ITS Examples Web Api client</Product> <Product>Gerst ITS Examples Web Api client</Product>
<Description>Exapmle Web Api client.</Description> <Description>Exapmle Web Api client.</Description>
<Version>0.0.0.0</Version> <Version>0.0.0.0</Version>
@@ -12,11 +12,6 @@
<FileVersion>0.0.0.0</FileVersion> <FileVersion>0.0.0.0</FileVersion>
</PropertyGroup> </PropertyGroup>
<PropertyGroup>
<TargetFramework>net5.0</TargetFramework>
<LangVersion>latest</LangVersion>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
<TreatWarningsAsErrors>true</TreatWarningsAsErrors> <TreatWarningsAsErrors>true</TreatWarningsAsErrors>
<CheckForOverflowUnderflow>true</CheckForOverflowUnderflow> <CheckForOverflowUnderflow>true</CheckForOverflowUnderflow>
@@ -32,20 +27,11 @@
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="GerstITS.IoC" Version="2021.7.17" /> <PackageReference Include="GerstITS.IoC" />
<PackageReference Include="GerstITS.IoC.DotNetCore" Version="2021.7.21" /> <PackageReference Include="GerstITS.IoC.DotNetCore" />
<PackageReference Include="GerstITS.System" Version="2021.7.20" /> <PackageReference Include="GerstITS.System" />
<PackageReference Include="GerstITS.Web" Version="2021.6.17" /> <PackageReference Include="GerstITS.Web" />
<PackageReference Include="GerstITS.Web.Rest" Version="2021.6.17" /> <PackageReference Include="GerstITS.Web.Rest" />
</ItemGroup>
<ItemGroup>
<Compile Update="Module.Configurations.cs">
<DependentUpon>Module.cs</DependentUpon>
</Compile>
<Compile Update="Module.CreationRules.cs">
<DependentUpon>Module.cs</DependentUpon>
</Compile>
</ItemGroup> </ItemGroup>
</Project> </Project>

View File

@@ -1,17 +1,16 @@
using GerstITS.Examples.WebClients.Examples.Api.Configurations; using GerstITS.Examples.WebClients.Examples.Api.Configurations;
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.WebClients.Examples.Api namespace GerstITS.Examples.WebClients.Examples.Api;
public sealed partial class Module
{ {
public sealed partial class Module #region Methods
private static void RegisterConfigurations(IServiceCollection container)
{ {
#region Methods container.AddSingleton<ExampleApiClientConfiguration>();
private static void RegisterConfigurations(IServiceCollection container)
{
container.AddSingleton<ExampleApiClientConfiguration>();
}
#endregion
} }
#endregion
} }

View File

@@ -2,17 +2,16 @@
using GerstITS.Web.WebClients; using GerstITS.Web.WebClients;
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.WebClients.Examples.Api namespace GerstITS.Examples.WebClients.Examples.Api;
public sealed partial class Module
{ {
public sealed partial class Module #region Methods
private static void RegisterCreationRules(IServiceCollection container)
{ {
#region Methods container.AddTransient<IWebServiceClientCreationRule, ExampleApiClientCreatingRule>();
private static void RegisterCreationRules(IServiceCollection container)
{
container.AddTransient<IWebServiceClientCreationRule, ExampleApiClientCreatingRule>();
}
#endregion
} }
#endregion
} }

View File

@@ -1,18 +1,17 @@
using GerstITS.IoC; using GerstITS.IoC;
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.WebClients.Examples.Api namespace GerstITS.Examples.WebClients.Examples.Api;
public sealed partial class Module : IIoCModule<IServiceCollection>
{ {
public sealed partial class Module : IIoCModule<IServiceCollection> #region IIoCModule
public void RegisterComponents(IServiceCollection container)
{ {
#region IIoCModule RegisterConfigurations(container);
RegisterCreationRules(container);
public void RegisterComponents(IServiceCollection container)
{
RegisterConfigurations(container);
RegisterCreationRules(container);
}
#endregion
} }
#endregion
} }

View File

@@ -1,20 +1,28 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<configuration> <configuration>
<config> <packageRestore>
<add key="repositoryPath" value="..\packages" /> <add key="enabled" value="True" />
</config> <add key="automatic" value="True" />
<packageRestore> </packageRestore>
<add key="enabled" value="True" /> <packageSources>
<add key="automatic" value="True" /> <clear />
</packageRestore> <add key="Gerst ITS" value="https://packages.gerst-it.com/nuget/public/v3/index.json" />
<packageSources> <add key="nuget.org - V2" value="https://www.nuget.org/api/v2/" />
<clear /> <add key="nuget.org - V3" value="https://api.nuget.org/v3/index.json" />
<add key="Gerst ITS" value="https://packages.gerst-it.com/nuget/public/v3/index.json" /> </packageSources>
<add key="nuget.org - V2" value="https://www.nuget.org/api/v2/" /> <disabledPackageSources>
<add key="nuget.org - V3" value="https://api.nuget.org/v3/index.json" />
</packageSources>
<disabledPackageSources>
</disabledPackageSources> </disabledPackageSources>
<activePackageSource> <activePackageSource>
</activePackageSource> </activePackageSource>
<packageSourceMapping>
<packageSource key="nuget.org - V2">
<package pattern="*" />
</packageSource>
<packageSource key="nuget.org - V3">
<package pattern="*" />
</packageSource>
<packageSource key="Gerst ITS">
<package pattern="GerstITS.*" />
</packageSource>
</packageSourceMapping>
</configuration> </configuration>