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;
using System.Linq;
using Microsoft.Extensions.Configuration;
namespace GerstITS.Examples.Api.Configurations;
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)
where TEnum : struct, IConvertible
{
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
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
}

View File

@@ -1,27 +1,25 @@
using GerstITS.Data.EntityFramework;
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,
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
AutoMigrate = configuration.GetValue<bool>($"{prefix}:{nameof(AutoMigrate)}");
}
#endregion
#region IMigrationConfiguration
public bool AutoMigrate { get; }
#endregion
}

View File

@@ -1,34 +1,33 @@
using GerstITS.Web.Api.Swagger;
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; }
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
}
#endregion
}

View File

@@ -1,34 +1,32 @@
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,
IConfiguration configuration)
{
var prefix = $"{parentPrefix}:Validate";
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
Issuer = configuration.GetValue<string>($"{prefix}:{nameof(Issuer)}");
Audience = configuration.GetValue<string>($"{prefix}:{nameof(Audience)}");
RsaPublicKey = configuration.GetValue<string>($"{prefix}:{nameof(RsaPublicKey)}");
NameClaimType = configuration.GetValue<string>($"{prefix}:{nameof(NameClaimType)}");
ValidateLifetime = configuration.GetValue<bool>($"{prefix}:{nameof(ValidateLifetime)}");
}
#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 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,
Microsoft.Extensions.Configuration.IConfiguration configuration)
{
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
Authority = configuration.GetValue<string>($"{prefix}:{nameof(Authority)}");
RequireHttpsMetadata = configuration.GetValue<bool>($"{prefix}:{nameof(RequireHttpsMetadata)}");
SaveToken = configuration.GetValue<bool>($"{prefix}:{nameof(SaveToken)}");
Authority = configuration.GetValue<string>($"{prefix}:{nameof(Authority)}");
RequireHttpsMetadata = configuration.GetValue<bool>($"{prefix}:{nameof(RequireHttpsMetadata)}");
SaveToken = configuration.GetValue<bool>($"{prefix}:{nameof(SaveToken)}");
Validate = new OpenIdValidationConfiguration(prefix, configuration);
}
Validate = new OpenIdValidationConfiguration(prefix, configuration);
}
#endregion
#endregion
#region IOpenIdConfiguration
#region IOpenIdConfiguration
public string Authority { get; }
public bool RequireHttpsMetadata { get; }
public bool SaveToken { get; }
public string Authority { get; }
public bool RequireHttpsMetadata { 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.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)
{
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
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
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
}

View File

@@ -1,30 +1,28 @@
using GerstITS.System.Configurations;
using GerstITS.Web.Api.Builder;
using Microsoft.AspNetCore.Builder;
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 = new ForwardedHeadersOptions
{
ForwardedHeaders = configuration.GetFlaggedEnum<ForwardedHeaders>($"{prefix}:{nameof(ForwardedHeadersOptions)}:{nameof(ForwardedHeadersOptions.ForwardedHeaders)}")
};
}
#endregion
#region IHeaderConfiguration
public ForwardedHeadersOptions ForwardedHeaders { get; }
#endregion
ForwardedHeaders = configuration.GetFlaggedEnum<ForwardedHeaders>($"{prefix}:{nameof(ForwardedHeadersOptions)}:{nameof(ForwardedHeadersOptions.ForwardedHeaders)}")
};
}
#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 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)
{
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
UseHttpsRedirection = configuration.GetValue<bool>($"{prefix}:{nameof(UseHttpsRedirection)}");
UseHsts = configuration.GetValue<bool>($"{prefix}:{nameof(UseHsts)}");
UseCors = configuration.GetValue<bool>($"{prefix}:{nameof(UseCors)}");
UseHttpsRedirection = configuration.GetValue<bool>($"{prefix}:{nameof(UseHttpsRedirection)}");
UseHsts = configuration.GetValue<bool>($"{prefix}:{nameof(UseHsts)}");
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
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
}

View File

@@ -1,29 +1,26 @@
using System;
using GerstITS.System.Configurations;
using GerstITS.System.Configurations;
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)
{
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
Name = configuration.GetValue<string>($"{prefix}:{nameof(Name)}");
Url = configuration.GetValue<Uri>($"{prefix}:{nameof(Url)}");
}
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 Uri Url { get; }
public string Name { get; }
public Uri Url { get; }
#endregion
}
#endregion
}

View File

@@ -1,46 +1,44 @@
using System;
using System.Diagnostics;
using GerstITS.Examples.Api.Configurations;
using System.Diagnostics;
using GerstITS.Common;
using GerstITS.System.Configurations;
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,
Microsoft.Extensions.Configuration.IConfiguration configuration)
{
var prefix = $"{parentPrefix}:{this.ToConfigurationPrefix()}";
var currentAssembly = typeof(WebApiConfiguration).Assembly;
var fileVersionInfo = FileVersionInfo.GetVersionInfo(currentAssembly.Location);
var currentAssembly = typeof(WebApiConfiguration).Assembly;
var fileVersionInfo = FileVersionInfo.GetVersionInfo(currentAssembly.Location);
Name = fileVersionInfo.ProductName;
Company = fileVersionInfo.CompanyName;
SupportEMail = configuration.GetValue<string>($"{prefix}:{nameof(SupportEMail)}");
TermsOfService = configuration.GetValue<Uri>($"{prefix}:{nameof(TermsOfService)}");
Name = fileVersionInfo.ProductName;
Company = fileVersionInfo.CompanyName;
SupportEMail = configuration.GetValue<string>($"{prefix}:{nameof(SupportEMail)}");
TermsOfService = configuration.GetValue<Uri>($"{prefix}:{nameof(TermsOfService)}");
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
Release = currentAssembly.GetName().Version;
License = new LicenseConfiguration(prefix, configuration);
Securities = new OpenApiSecuritySchemeConfiguration().AsEnumerable()
.ToList();
}
#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.System.Configurations;
using GerstITS.Web.Api.Builder;
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; }
public IOpenIdConfiguration OpenId { get; }
public ISwaggerConfiguration Swagger { get; set; }
public IEntityFrameworkMigrationConfiguration EntityFrameworkMigration { get; set; }
#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
EntityFrameworkMigration = new EntityFrameworkMigrationConfiguration(prefix, configuration);
//OpenId = new OpenIdConfiguration(prefix, configuration);
Server = new ServerConfiguration(prefix, configuration);
Swagger = new SwaggerConfiguration(prefix, configuration);
}
#endregion
}

View File

@@ -2,18 +2,21 @@
using GerstITS.Data;
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
{
StatusCode = HttpStatusCode.NotFound,
ReasonPhrase = "Enitity nicht gefunden",
Details = exception.Message
};
}
}
}
return new ExceptionTransformationInfo
{
StatusCode = HttpStatusCode.NotFound,
ReasonPhrase = "Enitity nicht gefunden",
Details = exception.Message
};
}
#endregion
}

View File

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

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_1 = "1.1";
public const string _1_0 = "1.0";
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.Validation;
using GerstITS.Web.Api;
using GerstITS.Web.Api.FluentApi;
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>
/// Controller is deprecated use newer version.
/// </summary>
[ApiController,
ApiVersion(Versions._1_0, Deprecated = true),
Route(ApplicationEnvironment.WebApi.ControllerRouteTemplate)]
public class ExampleController : FluentApiControllerBase
{
#region Fields
#region Fields
private readonly IExampleProvider _provider;
private readonly IExampleProvider _provider;
#endregion
#endregion
#region Constructors
#region Constructors
public ExampleController(IExampleProvider provider,
IValidator validator)
: base(validator)
{
_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
public ExampleController(IExampleProvider provider,
IValidator validator)
: base(validator)
{
_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
}

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.Validation;
using GerstITS.Web.Api;
using GerstITS.Web.Api.FluentApi;
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>
/// Is responsible to get employee organization assignment examples.
/// </summary>
[ApiController,
ApiVersion(Versions._1_1),
Route(ApplicationEnvironment.WebApi.ControllerRouteTemplate)]
public class ExampleController : FluentApiControllerBase
#region Fields
private readonly IExampleProvider _provider;
#endregion
#region Constructors
public ExampleController(IExampleProvider provider,
IValidator validator)
: base(validator)
{
#region Fields
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
_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
}

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

View File

@@ -1,22 +1,20 @@
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<WebApiConfiguration>();
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
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
}

View File

@@ -1,18 +1,16 @@
using GerstITS.Examples.Api.ExceptionHandling;
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
private static void RegisterExceptionHandling(IServiceCollection container)
{
container.RegisterExceptionTransformationsOf<ValidationExceptionTransformation>();
}
#endregion
container.RegisterExceptionTransformationsOf<ValidationExceptionTransformation>();
}
#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.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
private static void RegisterStartupTasks(IServiceCollection container)
{
container.RegisterStartupTasksOf<ExampleStartupTask>();
}
#endregion
container.RegisterStartupTasksOf<ExampleStartupTask>();
}
#endregion
}

View File

@@ -1,20 +1,17 @@
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
public void RegisterComponents(IServiceCollection container)
{
RegisterConfigurations(container);
RegisterExceptionHandling(container);
RegisterMvc(container);
RegisterStartupTasks(container);
}
#endregion
RegisterConfigurations(container);
RegisterExceptionHandling(container);
RegisterStartupTasks(container);
}
}
#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.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
public static void Main(string[] args)
{
BootstrapLogContext.Execute<Program>(_ => Run(args));
}
protected override void ConfigureWebHost(IWebHostBuilder webHostBuilder)
{
webHostBuilder.UseLogging()
.UseStartup<Startup>();
}
#endregion
HostingStartup.Use(args)
.Host()
.UseSerilog((context, configuration) => {
configuration.ReadFrom.Configuration(context.Configuration);
if (Common.ApplicationEnvironment.IsEfCoreActionStarted)
Debug.WriteLine("==========>>>>>>> Do NOT start Application!!!!");
})
.Services()
.Build()
.IfProduction(app => app.UsePreconfiguredHsts())
.IfDevelopment(app => app.UseDeveloperExceptionPage()
.UsePreconfiguredSwagger())
.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": {
"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": "*",
"WebApi": {
"Swagger": {
"SupportEMail": "support@baketronic.com",
"TermsOfService": "https://www.baketronic.com/impressum/",
"Licence": {
"SupportEMail": "support@example.com",
"TermsOfService": "https://www.example.com/impressum/",
"License": {
"Name": "MIT",
"Url": "https://opensource.org/licenses/MIT"
}
},
"EntityFrameworkmigration": {
"AutoMigrate": true
"AutoMigrate": true
},
"Server": {
"UseCors": true,
@@ -64,15 +64,16 @@
}
}
},
"NotifyOvenJob": {
"CronExpression": "*/30 * * * * ? *"
},
"SayHelloWorldJob": {
"CronExpression": "*/30 * * * * ? *",
"Name": "Example Job"
"Jobs": {
"SayHelloWorldJob": {
"CronExpression": "*/30 * * * * ? *",
"Name": "Example Job With Specific Name"
},
"SayHelloWorldWithDefaultNameUsageJob": {
"CronExpression": "*/30 * * * * ? *"
}
},
"Serilog": {
"Using": [ "Serilog.Sinks.Console", "Serilog.Sinks.RollingFile" ],
"MinimumLevel": {
"Default": "Debug",
"Override": {
@@ -88,11 +89,9 @@
}
},
{
"Name": "RollingFile",
"Name": "File",
"Args": {
"pathFormat": "bin/Debug/net5.0/Logs/{Date}.log.json",
"formatter": "Serilog.Formatting.Compact.CompactJsonFormatter, Serilog",
"outputTemplate": "{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} [{Level}] [{SourceContext}] [{EventId}] {Message}{NewLine}{Exception}",
"path": "../Logs/.log",
"retainedFileCountLimit": 90,
"rollingInterval": "Day",
"shared": true

View File

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

View File

@@ -1,51 +1,42 @@
using System.Diagnostics;
using System.Threading;
using GerstITS.Data;
using GerstITS.Examples.Jobs.SayHelloWorld.Configurations;
using GerstITS.Job;
using GerstITS.System.Environment;
using Quartz;
namespace GerstITS.Examples.Jobs.SayHelloWorld.Jobs
namespace GerstITS.Examples.Jobs.SayHelloWorld.Jobs;
[DisallowConcurrentExecution]
public class SayHelloWorldJob : JobBase
{
[DisallowConcurrentExecution]
public class SayHelloWorldJob : JobBase
#region Fields
private readonly SayHelloWorldJobConfiguration _configuration;
private readonly Stopwatch _stopWatch;
#endregion
#region Cosntructors
public SayHelloWorldJob(SayHelloWorldJobConfiguration configuration,
ISystemClock systemClock)
{
#region Fields
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
_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

@@ -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 Microsoft.Extensions.DependencyInjection;
namespace GerstITS.Examples.Jobs.SayHelloWorld
{
public sealed class Module : IIoCModule<IServiceCollection>
{
#region IIoCModule
namespace GerstITS.Examples.Jobs.SayHelloWorld;
public void RegisterComponents(IServiceCollection container)
{
container.RegisterJob<SayHelloWorldJob, SayHelloWorldJobConfiguration>();
}
public sealed class Module : IIoCModule<IServiceCollection>
{
#region IIoCModule
public void RegisterComponents(IServiceCollection container)
{
container.RegisterJob<SayHelloWorldJob, SayHelloWorldJobConfiguration>();
}
#endregion
}
}
#endregion
}

View File

@@ -1,13 +1,12 @@
namespace GerstITS.Examples.Logic.Example
{
public class Example
{
#region Properties
namespace GerstITS.Examples.Logic.Example;
public string FirstName { get; set; }
public string LastName { get; set; }
public string Description { get; set; }
public class Example
{
#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 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
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
_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
}

View File

@@ -1,19 +1,18 @@
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
public IntegerMapping()
{
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
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
}

View File

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

View File

@@ -2,19 +2,18 @@
using GerstITS.Mapping.AutoMapper;
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.RegisterMappingsOf<IExampleProvider>();
container.AddScoped<IExampleProvider, ExampleProvider>();
}
container.AddScoped<IExampleProvider, ExampleProvider>();
}
#endregion
}
#endregion
}

View File

@@ -4,19 +4,18 @@ using GerstITS.Search;
using GerstITS.Validation;
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.RegisterValidationRulesOf<IdValidationRule>();
container.AddScoped<ISortingProvider, SortingProvider>();
}
container.AddScoped<ISortingProvider, SortingProvider>();
}
#endregion
}
#endregion
}

View File

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

View File

@@ -1,31 +1,28 @@
using System;
using System.Linq;
using System.Linq.Expressions;
using System.Linq.Expressions;
using GerstITS.Common;
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
public static TEntity QueryBy<TEntity>(this IReadOnlyRepository repository, Expression<Func<TEntity, bool>> condition)
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
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
}

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;
using System.Linq.Expressions;
using System.Linq.Expressions;
using System.Reflection;
using GerstITS.Common;
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
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
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
}

View File

@@ -1,19 +1,18 @@
using FluentValidation;
using GerstITS.Validation;
namespace GerstITS.Examples.Logic.Shared.Validation
{
internal sealed class IdValidationRule : ValidationRuleBase<int>
{
#region Constructors
public IdValidationRule()
{
RuleFor(x => x)
.GreaterThan(0)
.OverridePropertyName("id");
}
namespace GerstITS.Examples.Logic.Shared.Validation;
#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>
<Company>Gerst ITS</Company>
<Authors>Gerst ITS</Authors>
<Copyright>© 2021 Gerst ITS</Copyright>
<Copyright>© 2025 Gerst ITS</Copyright>
<Product>Gerst ITS Examples Web Api client console application</Product>
<Description>Exapmle Web Api client console application.</Description>
<Version>0.0.0.0</Version>
@@ -13,8 +13,6 @@
</PropertyGroup>
<PropertyGroup>
<TargetFramework>net5.0</TargetFramework>
<LangVersion>latest</LangVersion>
<OutputType>Exe</OutputType>
</PropertyGroup>
@@ -43,15 +41,16 @@
</ItemGroup>
<ItemGroup>
<PackageReference Include="GerstITS.Common" Version="2021.6.24" />
<PackageReference Include="GerstITS.IoC" Version="2021.7.17" />
<PackageReference Include="GerstITS.IoC.DotNetCore" Version="2021.7.21" />
<PackageReference Include="GerstITS.System" Version="2021.7.20" />
<PackageReference Include="GerstITS.Web" Version="2021.6.17" />
<PackageReference Include="GerstITS.Web.Rest" Version="2021.6.17" />
<PackageReference Include="Microsoft.Extensions.Configuration" Version="5.0.0" />
<PackageReference Include="Microsoft.Extensions.Configuration.FileExtensions" Version="5.0.0" />
<PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="5.0.0" />
<PackageReference Include="GerstITS.Common" />
<PackageReference Include="GerstITS.IoC" />
<PackageReference Include="GerstITS.IoC.DotNetCore" />
<PackageReference Include="GerstITS.System" />
<PackageReference Include="GerstITS.Web" />
<PackageReference Include="GerstITS.Web.Rest" />
<PackageReference Include="Hocon.Extensions.Configuration" />
<PackageReference Include="Microsoft.Extensions.Configuration.FileExtensions" />
<PackageReference Include="Microsoft.Extensions.Configuration.Json" />
</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.DotNetCore;
using Microsoft.Extensions.Configuration;
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<IApplicationStart, TestRunner>();
container.AddTransient<IConfiguration>(c => new ConfigurationBuilder().SetBasePath(AppDomain.CurrentDomain.BaseDirectory)
.AddJsonFile("appsettings.json", false, true)
.Build());
}
#endregion
container.AddTransient<IConfiguration>(c => new ConfigurationBuilder().SetBasePath(AppDomain.CurrentDomain.BaseDirectory)
.AddJsonFile("appsettings.json", false, true)
.Build());
}
#endregion
}

View File

@@ -1,31 +1,30 @@
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
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
_bootstrapper = new DotNetCoreApplicationBootstrapper();
}
}
#endregion
#region Methods
private static void Main(string[] args)
{
_bootstrapper.Run();
}
#endregion
}

View File

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

View File

@@ -1,7 +1,7 @@
Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio Version 16
VisualStudioVersion = 16.0.31321.278
# Visual Studio Version 18
VisualStudioVersion = 18.0.11217.181 d18.0
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}"
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">
<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>

View File

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

View File

@@ -1,27 +1,26 @@
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}")]
Country Get(int id);
[WebMethod(WebMethods.Get),
ResourceUrl("Country/{id}")]
Country Get(int id);
[WebMethod(WebMethods.Get),
ResourceUrl("Country/Search")]
SearchResult<Country> Search(SearchCriteria criteria);
[WebMethod(WebMethods.Get),
ResourceUrl("Country/Search")]
SearchResult<Country> Search(SearchCriteria criteria);
[WebMethod(WebMethods.Post),
ResourceUrl("Country")]
Country Create(Country model);
[WebMethod(WebMethods.Post),
ResourceUrl("Country")]
Country Create(Country model);
[WebMethod(WebMethods.Put),
ResourceUrl("Country")]
void Update(Country model);
[WebMethod(WebMethods.Put),
ResourceUrl("Country")]
void Update(Country model);
[WebMethod(WebMethods.Delete),
ResourceUrl("Country/{id}")]
void Delete(int id);
}
[WebMethod(WebMethods.Delete),
ResourceUrl("Country/{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 string Name { get; set; }
public int Id { 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; }
public string Name { get; set; }
internal int Id { get; set; }
public string Name { get; set; }
public int? Skip { get; set; }
public int? Take { get; set; }
public int? Skip { get; set; }
public int? Take { get; set; }
public string SortBy { get; set; }
public SortingDirections SortDirection { get; set; }
public string SortBy { get; set; }
public SortingDirections SortDirection { get; set; }
#endregion
}
#endregion
}

View File

@@ -1,24 +1,20 @@
using System;
using System.Collections.Generic;
namespace GerstITS.Examples.WebClients.Examples.Api;
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
public int TotalCount { get; set; }
public IEnumerable<TItem> Result { get; set; }
#endregion
#region Constructors
public SearchResult()
{
Result = Array.Empty<TItem>();
}
#endregion
Result = Array.Empty<TItem>();
}
#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;
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>
<Company>Gerst ITS</Company>
<Authors>Gerst ITS</Authors>
<Copyright>© 2021 Gerst ITS</Copyright>
<Copyright>© 2025 Gerst ITS</Copyright>
<Product>Gerst ITS Examples Web Api client</Product>
<Description>Exapmle Web Api client.</Description>
<Version>0.0.0.0</Version>
@@ -12,11 +12,6 @@
<FileVersion>0.0.0.0</FileVersion>
</PropertyGroup>
<PropertyGroup>
<TargetFramework>net5.0</TargetFramework>
<LangVersion>latest</LangVersion>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
<TreatWarningsAsErrors>true</TreatWarningsAsErrors>
<CheckForOverflowUnderflow>true</CheckForOverflowUnderflow>
@@ -32,20 +27,11 @@
</PropertyGroup>
<ItemGroup>
<PackageReference Include="GerstITS.IoC" Version="2021.7.17" />
<PackageReference Include="GerstITS.IoC.DotNetCore" Version="2021.7.21" />
<PackageReference Include="GerstITS.System" Version="2021.7.20" />
<PackageReference Include="GerstITS.Web" Version="2021.6.17" />
<PackageReference Include="GerstITS.Web.Rest" Version="2021.6.17" />
</ItemGroup>
<ItemGroup>
<Compile Update="Module.Configurations.cs">
<DependentUpon>Module.cs</DependentUpon>
</Compile>
<Compile Update="Module.CreationRules.cs">
<DependentUpon>Module.cs</DependentUpon>
</Compile>
<PackageReference Include="GerstITS.IoC" />
<PackageReference Include="GerstITS.IoC.DotNetCore" />
<PackageReference Include="GerstITS.System" />
<PackageReference Include="GerstITS.Web" />
<PackageReference Include="GerstITS.Web.Rest" />
</ItemGroup>
</Project>

View File

@@ -1,17 +1,16 @@
using GerstITS.Examples.WebClients.Examples.Api.Configurations;
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
private static void RegisterConfigurations(IServiceCollection container)
{
container.AddSingleton<ExampleApiClientConfiguration>();
}
#endregion
container.AddSingleton<ExampleApiClientConfiguration>();
}
#endregion
}

View File

@@ -2,17 +2,16 @@
using GerstITS.Web.WebClients;
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
private static void RegisterCreationRules(IServiceCollection container)
{
container.AddTransient<IWebServiceClientCreationRule, ExampleApiClientCreatingRule>();
}
#endregion
container.AddTransient<IWebServiceClientCreationRule, ExampleApiClientCreatingRule>();
}
#endregion
}

View File

@@ -1,18 +1,17 @@
using GerstITS.IoC;
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
public void RegisterComponents(IServiceCollection container)
{
RegisterConfigurations(container);
RegisterCreationRules(container);
}
#endregion
RegisterConfigurations(container);
RegisterCreationRules(container);
}
#endregion
}

View File

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