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,11 +1,7 @@
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 #region Methods
public static TEnum GetFlaggedEnum<TEnum>(this IConfiguration configuration, string key) public static TEnum GetFlaggedEnum<TEnum>(this IConfiguration configuration, string key)
@@ -25,5 +21,4 @@ namespace GerstITS.Examples.Api.Configurations
} }
#endregion #endregion
}
} }

View File

@@ -1,11 +1,10 @@
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 #region Constructors
public EntityFrameworkMigrationConfiguration(string parentPrefix, public EntityFrameworkMigrationConfiguration(string parentPrefix,
@@ -23,5 +22,4 @@ namespace GerstITS.Examples.Api.Configurations
public bool AutoMigrate { get; } public bool AutoMigrate { get; }
#endregion #endregion
}
} }

View File

@@ -1,11 +1,11 @@
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 #region Properties
public bool AllowAnonymous { get; } public bool AllowAnonymous { get; }
@@ -30,5 +30,4 @@ namespace BakeTronic.Web.Api.Configurations
} }
#endregion #endregion
}
} }

View File

@@ -1,10 +1,9 @@
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 #region Constructors
public OpenIdValidationConfiguration(string parentPrefix, public OpenIdValidationConfiguration(string parentPrefix,
@@ -15,7 +14,7 @@ namespace BakeTronic.Web.Api.Configurations
Issuer = configuration.GetValue<string>($"{prefix}:{nameof(Issuer)}"); Issuer = configuration.GetValue<string>($"{prefix}:{nameof(Issuer)}");
Audience = configuration.GetValue<string>($"{prefix}:{nameof(Audience)}"); Audience = configuration.GetValue<string>($"{prefix}:{nameof(Audience)}");
RsaPublicKey = configuration.GetValue<string>($"{prefix}:{nameof(RsaPublicKey)}"); RsaPublicKey = configuration.GetValue<string>($"{prefix}:{nameof(RsaPublicKey)}");
RequiredClaimType = configuration.GetValue<string>($"{prefix}:{nameof(RequiredClaimType)}"); NameClaimType = configuration.GetValue<string>($"{prefix}:{nameof(NameClaimType)}");
ValidateLifetime = configuration.GetValue<bool>($"{prefix}:{nameof(ValidateLifetime)}"); ValidateLifetime = configuration.GetValue<bool>($"{prefix}:{nameof(ValidateLifetime)}");
} }
@@ -26,9 +25,8 @@ namespace BakeTronic.Web.Api.Configurations
public string Issuer { get; } public string Issuer { get; }
public string Audience { get; } public string Audience { get; }
public string RsaPublicKey { get; } public string RsaPublicKey { get; }
public string RequiredClaimType { get; } public string NameClaimType { get; }
public bool ValidateLifetime { get; } public bool ValidateLifetime { get; }
#endregion #endregion
}
} }

View File

@@ -1,12 +1,10 @@
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 #region Constructors
public OpenIdConfiguration(string parentPrefix, public OpenIdConfiguration(string parentPrefix,
@@ -32,5 +30,4 @@ namespace GerstITS.Examples.Api.Configurations
public IOpenIdValidationConfiguration Validate { get; } public IOpenIdValidationConfiguration Validate { get; }
#endregion #endregion
}
} }

View File

@@ -1,11 +1,10 @@
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 #region Constructors
public CorsPolicyConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration) public CorsPolicyConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration)
@@ -28,5 +27,4 @@ namespace BakeTronic.Web.Api.Configurations
public string[] AllowedMethods { get; set; } public string[] AllowedMethods { get; set; }
#endregion #endregion
}
} }

View File

@@ -1,12 +1,11 @@
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 #region Constructors
public WebApiHeadersConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration) public WebApiHeadersConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration)
@@ -26,5 +25,4 @@ namespace GerstITS.Examples.Api.Configurations
public ForwardedHeadersOptions ForwardedHeaders { get; } public ForwardedHeadersOptions ForwardedHeaders { get; }
#endregion #endregion
}
} }

View File

@@ -1,12 +1,10 @@
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 #region Constructors
public ServerConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration) public ServerConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration)
@@ -32,5 +30,4 @@ namespace BakeTronic.Web.Api.Configurations
public ICorsPolicy CorsPolicy { get; } public ICorsPolicy CorsPolicy { get; }
#endregion #endregion
}
} }

View File

@@ -1,12 +1,10 @@
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 #region Constructors
public LicenseConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration) public LicenseConfiguration(string parentPrefix, Microsoft.Extensions.Configuration.IConfiguration configuration)
@@ -25,5 +23,4 @@ namespace BakeTronic.Web.Api.Configurations
public Uri Url { get; } public Uri Url { get; }
#endregion #endregion
}
} }

View File

@@ -1,14 +1,12 @@
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 #region Constructors
public SwaggerConfiguration(string parentPrefix, public SwaggerConfiguration(string parentPrefix,
@@ -26,7 +24,8 @@ namespace BakeTronic.Web.Api.Configurations
Release = currentAssembly.GetName().Version; Release = currentAssembly.GetName().Version;
License = new LicenseConfiguration(prefix, configuration); License = new LicenseConfiguration(prefix, configuration);
Security = new OpenApiSecuritySchemeConfiguration(); Securities = new OpenApiSecuritySchemeConfiguration().AsEnumerable()
.ToList();
} }
#endregion #endregion
@@ -38,9 +37,8 @@ namespace BakeTronic.Web.Api.Configurations
public string SupportEMail { get; } public string SupportEMail { get; }
public Uri TermsOfService { get; } public Uri TermsOfService { get; }
public Version Release { get; } public Version Release { get; }
public IEnumerable<IOpenApiSecuritySchemeConfiguration> Securities { get; }
public ILicense License { get; } public ILicense License { get; }
public IOpenApiSecuritySchemeConfiguration Security { get; }
#endregion #endregion
}
} }

View File

@@ -1,14 +1,13 @@
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 #region Properties
public IServerConfiguration Server { get; } public IServerConfiguration Server { get; }
@@ -25,11 +24,10 @@ namespace GerstITS.Examples.Api.Configurations
var prefix = this.ToConfigurationPrefix(); var prefix = this.ToConfigurationPrefix();
EntityFrameworkMigration = new EntityFrameworkMigrationConfiguration(prefix, configuration); EntityFrameworkMigration = new EntityFrameworkMigrationConfiguration(prefix, configuration);
OpenId = new OpenIdConfiguration(prefix, configuration); //OpenId = new OpenIdConfiguration(prefix, configuration);
Server = new ServerConfiguration(prefix, configuration); Server = new ServerConfiguration(prefix, configuration);
Swagger = new SwaggerConfiguration(prefix, configuration); Swagger = new SwaggerConfiguration(prefix, configuration);
} }
#endregion #endregion
}
} }

View File

@@ -2,10 +2,12 @@
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
@@ -15,5 +17,6 @@ namespace GerstITS.Examples.Api.ExceptionHandling
Details = exception.Message Details = exception.Message
}; };
} }
}
#endregion
} }

View File

@@ -2,10 +2,10 @@
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>
{ {
internal sealed class ValidationExceptionTransformation : ExceptionTransformationBase<ValidationException>
{
#region Methods #region Methods
protected override ExceptionTransformationInfo CreateExceptionTransformationInfo(ValidationException exception, string ticketId) protected override ExceptionTransformationInfo CreateExceptionTransformationInfo(ValidationException exception, string ticketId)
@@ -19,5 +19,4 @@ namespace GerstITS.Examples.Api.ExceptionHandling
} }
#endregion #endregion
}
} }

View File

@@ -3,10 +3,10 @@ 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# #region Fields#
private readonly IExampleProvider _provider; private readonly IExampleProvider _provider;
@@ -35,5 +35,4 @@ namespace GerstITS.Examples.Api.StartupTasks
} }
#endregion #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,20 +1,21 @@
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> /// <summary>
/// Controller is deprecated use newer version. /// Controller is deprecated use newer version.
/// </summary> /// </summary>
[ApiController, [ApiController,
ApiVersion(Versions._1_0, Deprecated = true), ApiVersion(Versions._1_0, Deprecated = true),
Route(ApplicationEnvironment.WebApi.ControllerRouteTemplate)] Route(ApplicationEnvironment.WebApi.ControllerRouteTemplate)]
public class ExampleController : FluentApiControllerBase public class ExampleController : FluentApiControllerBase
{ {
#region Fields #region Fields
private readonly IExampleProvider _provider; private readonly IExampleProvider _provider;
@@ -48,5 +49,4 @@ namespace GerstITS.Examples.Api.Controllers
} }
#endregion #endregion
}
} }

View File

@@ -1,20 +1,21 @@
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> /// <summary>
/// Is responsible to get employee organization assignment examples. /// Is responsible to get employee organization assignment examples.
/// </summary> /// </summary>
[ApiController, [ApiController,
ApiVersion(Versions._1_1), ApiVersion(Versions._1_1),
Route(ApplicationEnvironment.WebApi.ControllerRouteTemplate)] Route(ApplicationEnvironment.WebApi.ControllerRouteTemplate)]
public class ExampleController : FluentApiControllerBase public class ExampleController : FluentApiControllerBase
{ {
#region Fields #region Fields
private readonly IExampleProvider _provider; private readonly IExampleProvider _provider;
@@ -48,5 +49,4 @@ namespace GerstITS.Examples.Api.Controllers._1._1
} }
#endregion #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,10 +1,9 @@
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 #region Methods
private static void RegisterConfigurations(IServiceCollection container) private static void RegisterConfigurations(IServiceCollection container)
@@ -18,5 +17,4 @@ namespace GerstITS.Examples.Api
} }
#endregion #endregion
}
} }

View File

@@ -1,11 +1,10 @@
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 #region Methods
private static void RegisterExceptionHandling(IServiceCollection container) private static void RegisterExceptionHandling(IServiceCollection container)
@@ -14,5 +13,4 @@ namespace GerstITS.Examples.Api
} }
#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,11 +1,10 @@
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 #region Methods
private static void RegisterStartupTasks(IServiceCollection container) private static void RegisterStartupTasks(IServiceCollection container)
@@ -14,5 +13,4 @@ namespace GerstITS.Examples.Api
} }
#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 #region IIoCModule
public void RegisterComponents(IServiceCollection container) public void RegisterComponents(IServiceCollection container)
{ {
RegisterConfigurations(container); RegisterConfigurations(container);
RegisterExceptionHandling(container); RegisterExceptionHandling(container);
RegisterMvc(container);
RegisterStartupTasks(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 #region Methods
public static void Main(string[] args) public static void Main(string[] args)
{ {
BootstrapLogContext.Execute<Program>(_ => Run(args)); HostingStartup.Use(args)
} .Host()
.UseSerilog((context, configuration) => {
configuration.ReadFrom.Configuration(context.Configuration);
protected override void ConfigureWebHost(IWebHostBuilder webHostBuilder) if (Common.ApplicationEnvironment.IsEfCoreActionStarted)
{ Debug.WriteLine("==========>>>>>>> Do NOT start Application!!!!");
webHostBuilder.UseLogging() })
.UseStartup<Startup>(); .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 #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,9 +9,9 @@
"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"
} }
@@ -64,15 +64,16 @@
} }
} }
}, },
"NotifyOvenJob": { "Jobs": {
"CronExpression": "*/30 * * * * ? *"
},
"SayHelloWorldJob": { "SayHelloWorldJob": {
"CronExpression": "*/30 * * * * ? *", "CronExpression": "*/30 * * * * ? *",
"Name": "Example Job" "Name": "Example Job With Specific Name"
},
"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 Properties
public string Name { get; }
#endregion
#region Constructors #region Constructors
public SayHelloWorldJobConfiguration(Microsoft.Extensions.Configuration.IConfiguration configuration) public SayHelloWorldJobConfiguration(Microsoft.Extensions.Configuration.IConfiguration configuration)
: base(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,33 +1,26 @@
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]
public class SayHelloWorldJob : JobBase
{
#region Fields #region Fields
private readonly SayHelloWorldJobConfiguration _configuration; private readonly SayHelloWorldJobConfiguration _configuration;
private readonly Stopwatch _stopWatch; private readonly Stopwatch _stopWatch;
private readonly IRepository _repository;
private readonly ISystemClock _systemClock;
#endregion #endregion
#region Cosntructors #region Cosntructors
public SayHelloWorldJob(SayHelloWorldJobConfiguration configuration, public SayHelloWorldJob(SayHelloWorldJobConfiguration configuration,
IRepository repository,
ISystemClock systemClock) ISystemClock systemClock)
{ {
_systemClock = systemClock;
_repository = repository;
_configuration = configuration; _configuration = configuration;
_stopWatch = new Stopwatch(); _stopWatch = new Stopwatch();
} }
@@ -40,12 +33,10 @@ namespace GerstITS.Examples.Jobs.SayHelloWorld.Jobs
{ {
_stopWatch.Restart(); _stopWatch.Restart();
Thread.Sleep(4000); Thread.Sleep(4000);
var now = _systemClock.UtcNow;
_stopWatch.Stop(); _stopWatch.Stop();
Debug.WriteLine($"---> Say hello to world from {_configuration.Name}, Duration: {_stopWatch.ElapsedMilliseconds / 1000}s"); Debug.WriteLine($"---> Say hello to world from {_configuration.Name}, Duration: {_stopWatch.ElapsedMilliseconds / 1000}s");
} }
#endregion #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,10 +4,10 @@ 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>
{ {
public sealed class Module : IIoCModule<IServiceCollection>
{
#region IIoCModule #region IIoCModule
public void RegisterComponents(IServiceCollection container) public void RegisterComponents(IServiceCollection container)
@@ -16,5 +16,4 @@ namespace GerstITS.Examples.Jobs.SayHelloWorld
} }
#endregion #endregion
}
} }

View File

@@ -1,7 +1,7 @@
namespace GerstITS.Examples.Logic.Example namespace GerstITS.Examples.Logic.Example;
public class Example
{ {
public class Example
{
#region Properties #region Properties
public string FirstName { get; set; } public string FirstName { get; set; }
@@ -9,5 +9,4 @@
public string Description { 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(int id);
Example GetById_v1_1(int id); Example GetById_v1_1(int id);
}
} }

View File

@@ -1,10 +1,10 @@
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 #region Fields
private readonly IMapper _mapper; private readonly IMapper _mapper;
@@ -47,5 +47,4 @@ namespace GerstITS.Examples.Logic.Example
} }
#endregion #endregion
}
} }

View File

@@ -1,9 +1,9 @@
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 #region Construtcors
public IntegerMapping() public IntegerMapping()
@@ -15,5 +15,4 @@ namespace GerstITS.Examples.Logic.Example
} }
#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,10 +2,10 @@
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 #region Methods
private static void RegisterExample(IServiceCollection container) private static void RegisterExample(IServiceCollection container)
@@ -16,5 +16,4 @@ namespace GerstITS.Examples.Logic
} }
#endregion #endregion
}
} }

View File

@@ -4,10 +4,10 @@ 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 #region Methods
private static void RegisterShared(IServiceCollection container) private static void RegisterShared(IServiceCollection container)
@@ -18,5 +18,4 @@ namespace GerstITS.Examples.Logic
} }
#endregion #endregion
}
} }

View File

@@ -1,10 +1,10 @@
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>
{ {
public sealed partial class Module : IIoCModule<IServiceCollection>
{
#region IIoCModule #region IIoCModule
public void RegisterComponents(IServiceCollection container) public void RegisterComponents(IServiceCollection container)
@@ -14,5 +14,4 @@ namespace GerstITS.Examples.Logic
} }
#endregion #endregion
}
} }

View File

@@ -1,13 +1,11 @@
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 #region Methods
public static TEntity QueryBy<TEntity>(this IReadOnlyRepository repository, Expression<Func<TEntity, bool>> condition) public static TEntity QueryBy<TEntity>(this IReadOnlyRepository repository, Expression<Func<TEntity, bool>> condition)
@@ -27,5 +25,4 @@ namespace GerstITS.Examples.Logic.Shared
} }
#endregion #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,14 +1,12 @@
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 #region ISortingProvider
public bool CanSort<TItem>(IQueryable<TItem> query) public bool CanSort<TItem>(IQueryable<TItem> query)
@@ -46,5 +44,4 @@ namespace GerstITS.Examples.Logic.Shared.Search.Sorting
} }
#endregion #endregion
}
} }

View File

@@ -1,10 +1,10 @@
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>
{ {
internal sealed class IdValidationRule : ValidationRuleBase<int>
{
#region Constructors #region Constructors
public IdValidationRule() public IdValidationRule()
@@ -15,5 +15,4 @@ namespace GerstITS.Examples.Logic.Shared.Validation
} }
#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 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,14 +1,13 @@
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 #region IIoCModule
public void RegisterComponents(IServiceCollection container) public void RegisterComponents(IServiceCollection container)
@@ -21,5 +20,4 @@ namespace GerstITS.Examples.WebClient.Console
} }
#endregion #endregion
}
} }

View File

@@ -1,9 +1,9 @@
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 #region Fields
private static readonly DotNetCoreApplicationBootstrapper _bootstrapper; private static readonly DotNetCoreApplicationBootstrapper _bootstrapper;
@@ -27,5 +27,4 @@ namespace GerstITS.Examples.WebClient.Console
} }
#endregion #endregion
}
} }

View File

@@ -1,13 +1,11 @@
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 #region Fields
private readonly IWebClient _webClient; private readonly IWebClient _webClient;
@@ -47,5 +45,4 @@ namespace GerstITS.Examples.WebClient.Console.Tests
} }
#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,10 +1,10 @@
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
{ {
internal class ExampleApiClientConfiguration : RestWebServiceConfigurationBase
{
#region Constructors #region Constructors
public ExampleApiClientConfiguration(IConfiguration configuration) public ExampleApiClientConfiguration(IConfiguration configuration)
@@ -13,5 +13,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api.Configurations
} }
#endregion #endregion
}
} }

View File

@@ -1,9 +1,9 @@
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), [WebMethod(WebMethods.Get),
ResourceUrl("Country/{id}")] ResourceUrl("Country/{id}")]
Country Get(int id); Country Get(int id);
@@ -23,5 +23,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api
[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,7 +1,7 @@
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; }
@@ -14,5 +14,4 @@
public SortingDirections SortDirection { get; set; } public SortingDirections SortDirection { get; set; }
#endregion #endregion
}
} }

View File

@@ -1,10 +1,7 @@
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 #region Properties
public int TotalCount { get; set; } public int TotalCount { get; set; }
@@ -20,5 +17,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api
} }
#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, Ascending = 0,
Descending Descending
}
} }

View File

@@ -1,11 +1,10 @@
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 #region Properties
protected override Type[] SupportedTypes => new[] { typeof(ICountry) }; protected override Type[] SupportedTypes => new[] { typeof(ICountry) };
@@ -21,5 +20,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api.CreationRules
} }
#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,10 +1,10 @@
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 #region Methods
private static void RegisterConfigurations(IServiceCollection container) private static void RegisterConfigurations(IServiceCollection container)
@@ -13,5 +13,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api
} }
#endregion #endregion
}
} }

View File

@@ -2,10 +2,10 @@
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 #region Methods
private static void RegisterCreationRules(IServiceCollection container) private static void RegisterCreationRules(IServiceCollection container)
@@ -14,5 +14,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api
} }
#endregion #endregion
}
} }

View File

@@ -1,10 +1,10 @@
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 #region IIoCModule
public void RegisterComponents(IServiceCollection container) public void RegisterComponents(IServiceCollection container)
@@ -14,5 +14,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api
} }
#endregion #endregion
}
} }

View File

@@ -1,8 +1,5 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<configuration> <configuration>
<config>
<add key="repositoryPath" value="..\packages" />
</config>
<packageRestore> <packageRestore>
<add key="enabled" value="True" /> <add key="enabled" value="True" />
<add key="automatic" value="True" /> <add key="automatic" value="True" />
@@ -17,4 +14,15 @@
</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>