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;
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)
@@ -25,5 +21,4 @@ namespace GerstITS.Examples.Api.Configurations
}
#endregion
}
}

View File

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

View File

@@ -1,11 +1,11 @@
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; }
@@ -30,5 +30,4 @@ namespace BakeTronic.Web.Api.Configurations
}
#endregion
}
}

View File

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

View File

@@ -1,11 +1,10 @@
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)
@@ -28,5 +27,4 @@ namespace BakeTronic.Web.Api.Configurations
public string[] AllowedMethods { get; set; }
#endregion
}
}

View File

@@ -1,12 +1,11 @@
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)
@@ -26,5 +25,4 @@ namespace GerstITS.Examples.Api.Configurations
public ForwardedHeadersOptions ForwardedHeaders { get; }
#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 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)
@@ -32,5 +30,4 @@ namespace BakeTronic.Web.Api.Configurations
public ICorsPolicy CorsPolicy { get; }
#endregion
}
}

View File

@@ -1,12 +1,10 @@
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)
@@ -25,5 +23,4 @@ namespace BakeTronic.Web.Api.Configurations
public Uri Url { get; }
#endregion
}
}

View File

@@ -1,14 +1,12 @@
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,
@@ -26,7 +24,8 @@ namespace BakeTronic.Web.Api.Configurations
Release = currentAssembly.GetName().Version;
License = new LicenseConfiguration(prefix, configuration);
Security = new OpenApiSecuritySchemeConfiguration();
Securities = new OpenApiSecuritySchemeConfiguration().AsEnumerable()
.ToList();
}
#endregion
@@ -38,9 +37,8 @@ namespace BakeTronic.Web.Api.Configurations
public string SupportEMail { get; }
public Uri TermsOfService { get; }
public Version Release { get; }
public IEnumerable<IOpenApiSecuritySchemeConfiguration> Securities { get; }
public ILicense License { get; }
public IOpenApiSecuritySchemeConfiguration Security { get; }
#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.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; }
@@ -25,11 +24,10 @@ namespace GerstITS.Examples.Api.Configurations
var prefix = this.ToConfigurationPrefix();
EntityFrameworkMigration = new EntityFrameworkMigrationConfiguration(prefix, configuration);
OpenId = new OpenIdConfiguration(prefix, configuration);
//OpenId = new OpenIdConfiguration(prefix, configuration);
Server = new ServerConfiguration(prefix, configuration);
Swagger = new SwaggerConfiguration(prefix, configuration);
}
#endregion
}
}

View File

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

View File

@@ -2,10 +2,10 @@
using System.Net;
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
protected override ExceptionTransformationInfo CreateExceptionTransformationInfo(ValidationException exception, string ticketId)
@@ -19,5 +19,4 @@ namespace GerstITS.Examples.Api.ExceptionHandling
}
#endregion
}
}

View File

@@ -3,10 +3,10 @@ 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;
@@ -35,5 +35,4 @@ namespace GerstITS.Examples.Api.StartupTasks
}
#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
public const string _1_0 = "1.0";
public const string _1_1 = "1.1";
#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.Validation;
using GerstITS.Web.Api;
using GerstITS.Web.Api.FluentApi;
using Microsoft.AspNetCore.Mvc;
namespace GerstITS.Examples.Api.Controllers
{
/// <summary>
/// Controller is deprecated use newer version.
/// </summary>
[ApiController,
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
{
public class ExampleController : FluentApiControllerBase
{
#region Fields
private readonly IExampleProvider _provider;
@@ -48,5 +49,4 @@ namespace GerstITS.Examples.Api.Controllers
}
#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.Validation;
using GerstITS.Web.Api;
using GerstITS.Web.Api.FluentApi;
using Microsoft.AspNetCore.Mvc;
namespace GerstITS.Examples.Api.Controllers._1._1
{
/// <summary>
/// Is responsible to get employee organization assignment examples.
/// </summary>
[ApiController,
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
{
public class ExampleController : FluentApiControllerBase
{
#region Fields
private readonly IExampleProvider _provider;
@@ -48,5 +49,4 @@ namespace GerstITS.Examples.Api.Controllers._1._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,10 +1,9 @@
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)
@@ -18,5 +17,4 @@ namespace GerstITS.Examples.Api
}
#endregion
}
}

View File

@@ -1,11 +1,10 @@
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)
@@ -14,5 +13,4 @@ namespace GerstITS.Examples.Api
}
#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.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)
@@ -14,5 +13,4 @@ namespace GerstITS.Examples.Api
}
#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)
{
RegisterConfigurations(container);
RegisterExceptionHandling(container);
RegisterMvc(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)
{
BootstrapLogContext.Execute<Program>(_ => Run(args));
}
HostingStartup.Use(args)
.Host()
.UseSerilog((context, configuration) => {
configuration.ReadFrom.Configuration(context.Configuration);
protected override void ConfigureWebHost(IWebHostBuilder webHostBuilder)
{
webHostBuilder.UseLogging()
.UseStartup<Startup>();
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,9 +9,9 @@
"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"
}
@@ -64,15 +64,16 @@
}
}
},
"NotifyOvenJob": {
"CronExpression": "*/30 * * * * ? *"
},
"Jobs": {
"SayHelloWorldJob": {
"CronExpression": "*/30 * * * * ? *",
"Name": "Example Job"
"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 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
}
}

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,33 +1,26 @@
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;
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();
}
@@ -40,12 +33,10 @@ namespace GerstITS.Examples.Jobs.SayHelloWorld.Jobs
{
_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
}
}

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 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
public void RegisterComponents(IServiceCollection container)
@@ -16,5 +16,4 @@ namespace GerstITS.Examples.Jobs.SayHelloWorld
}
#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
public string FirstName { get; set; }
@@ -9,5 +9,4 @@
public string Description { get; set; }
#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);
}
}

View File

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

View File

@@ -1,9 +1,9 @@
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()
@@ -15,5 +15,4 @@ namespace GerstITS.Examples.Logic.Example
}
#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,10 +2,10 @@
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)
@@ -16,5 +16,4 @@ namespace GerstITS.Examples.Logic
}
#endregion
}
}

View File

@@ -4,10 +4,10 @@ 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)
@@ -18,5 +18,4 @@ namespace GerstITS.Examples.Logic
}
#endregion
}
}

View File

@@ -1,10 +1,10 @@
using GerstITS.IoC;
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
public void RegisterComponents(IServiceCollection container)
@@ -14,5 +14,4 @@ namespace GerstITS.Examples.Logic
}
#endregion
}
}

View File

@@ -1,13 +1,11 @@
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)
@@ -27,5 +25,4 @@ namespace GerstITS.Examples.Logic.Shared
}
#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;
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)
@@ -46,5 +44,4 @@ namespace GerstITS.Examples.Logic.Shared.Search.Sorting
}
#endregion
}
}

View File

@@ -1,10 +1,10 @@
using FluentValidation;
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
public IdValidationRule()
@@ -15,5 +15,4 @@ namespace GerstITS.Examples.Logic.Shared.Validation
}
#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,14 +1,13 @@
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)
@@ -21,5 +20,4 @@ namespace GerstITS.Examples.WebClient.Console
}
#endregion
}
}

View File

@@ -1,9 +1,9 @@
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;
@@ -27,5 +27,4 @@ namespace GerstITS.Examples.WebClient.Console
}
#endregion
}
}

View File

@@ -1,13 +1,11 @@
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;
@@ -47,5 +45,4 @@ namespace GerstITS.Examples.WebClient.Console.Tests
}
#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,10 +1,10 @@
using GerstITS.Web.Rest.WebClients;
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
public ExampleApiClientConfiguration(IConfiguration configuration)
@@ -13,5 +13,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api.Configurations
}
#endregion
}
}

View File

@@ -1,9 +1,9 @@
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);
@@ -23,5 +23,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api
[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
public int Id { get; set; }
public string Name { get; set; }
#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
internal int Id { get; set; }
@@ -14,5 +14,4 @@
public SortingDirections SortDirection { get; set; }
#endregion
}
}

View File

@@ -1,10 +1,7 @@
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; }
@@ -20,5 +17,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api
}
#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
}
}

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;
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) };
@@ -21,5 +20,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api.CreationRules
}
#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,10 +1,10 @@
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)
@@ -13,5 +13,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api
}
#endregion
}
}

View File

@@ -2,10 +2,10 @@
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)
@@ -14,5 +14,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api
}
#endregion
}
}

View File

@@ -1,10 +1,10 @@
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)
@@ -14,5 +14,4 @@ namespace GerstITS.Examples.WebClients.Examples.Api
}
#endregion
}
}

View File

@@ -1,8 +1,5 @@
<?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" />
@@ -17,4 +14,15 @@
</disabledPackageSources>
<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>