- Upgrade target framework to .NET 8 and a lot of refactoring
- Upgrade target framework to .NET 6 and a lot of refactoring
- Upgrade target framework to .NET 5 and a lot of refactoring
- Add ViennaNET.Messaging.ActiveMQ, split ViennaNET.Messaging.Tests
- Extension ViennaNET.Redis, ViennaNET.Utils.Orm
- Minor changes in ViennaNET.Messaging, ViennaNET.Messaging.RabbitMQQueue, ViennaNET.Orm
- Minor changes in ViennaNET.Messaging, ViennaNET.Messaging.MQSeriesQueue, ViennaNET.Orm, ViennaNET.Redis, ViennaNET.WebApi
- Refactor logging
- Various small bugfixes in Excel, Messaging and WebApi
- Change Messaging
- Added ORM DB2 integration
- Change Messaging pooling process
- Added LoggingAdapterProvider - wrapper over ViennaNET.Logging.Logger to switch to standard Microsoft.Extensions.Logging.ILogger. Now ILogger can be used, but internally it will work like ViennaNET.Logging.Logger. After the complete translation of the libraries to ILogger, the ViennaNET.Logging library will be abandoned
In order for the current logging option to continue working as it is, you need to add the section to the service configuration file:
"Logging": {
"UseLegacyLogger": true,
"LogLevel": {
"Default": "Trace",
"Microsoft": "Warning",
"Microsoft.Hosting.Lifetime": "Information"
}
}
- For Rabbit queues, added the ability to create additional bindings through the routings configuration. Bindgin is the link between the exchange point and the queue. For exchageType direct and topic, you can create multiple peer-to-queue connections, and when sending a message with different rountigKey values to the peer, messages to one or more queues. The direct type requires a complete match of rountigKey with the name of the link between the exchange point and the queue. Whereas topic allows you to use a pattern such as *.green.* In the name of the connection. This revision allows you to create additional links of the exchange point with the queue to the default link, which has the name of the queue identifier from the configuration. This is necessary in order to be able to control where the message will go when it is sent to the exchange point in one or more queues, with the same configuration of routes from the exchange point to the queues.
- For HttpClients added Basic-authentication
- Added optional loading of an additional configuration file, which is selected by the value of the environment variable: https://docs.microsoft.com/en-us/aspnet/core/fundamentals/environments?view=aspnetcore-3.1
- MQSeriesQueue - selectors improved
- Protection - added the ability to encrypt passwords for connecting to databases
- HttpClients.NoAuthentication - added the ability to anonymously connect to other services
- WebApi.CompanyHostBuilder - add enironment variables to configuration
Changed CallContextHeaders headers. In case of their use, it is necessary to take into account the new formats.
We have added ICallContext. This abstraction receive and hold some context data such as request id, user name, domain and so on to pass in microservices by different channels: Http-requests and queue messaging. SecurityContextFactories now uses this context to build authentication data.
If you used manual installation of SimpleInjector packages, you will find that DiagnosticPackage is deleted: since this release it register automatically. Just delete DiagnosticPackage registration in your code.
Add more libraries
Rebranding Company.Framework to ViennaNET. ViennaNET.WebApi.* Was made based on AspNetCore 3, and .NET Core 3.1 is recommended for its use. Assemblies with configurators were renamed to ViennaNET.WebApi.Configurators.*, And some of them were merged or split. In the new version, the use of composite configurators has become easier, for example, if earlier it was necessary to call several extension methods, now only one public connection method remains in each configurator.
- AspNetCore 3 is not compatible with the classic .NET Framework, only with .NET Core 2+.
- In the new version of the ViennaNET.WebApi. * Libraries, some incompatible changes have been made. Assemblies with configurators were renamed ViennaNET.WebApi.Configurators. *, As well as some of them were merged or divided. To migrate existing services to new versions of these libraries, you must perform the migration.
- In SecurityKeysContainer, the default values for the publisher and the audience have changed, which means that you need to check the compatibility of these parameters with existing authorization services. It is better in the configuration to explicitly override these fields as in all services.
Migration of AspNetCore applications from ViennaNET.WebApi 1.*.* (NET Core 2.2) to 2.*.* (NET Core 3.1)
- In all assemblies using netcoreapp2.2, change to net6.0.
- In the main assembly with the service, delete the link to the ViennaNET.WebApi.DefaultConfiguration package for the service on Kestrel or ViennaNET.WebApi.DefaultHttpSysRunner for the service on HttpSys.
- Install the latest version of the package (2. *.*) ViennaNET.WebApi.Runners.BaseKestrel or ViennaNET.WebApi.Runners.BaseHttpSys, respectively.
- We also update versions of Company libraries to (2. *.*) In all assemblies. Version conflicts with third-party libraries (for example, SimpleInjector) may occur, so they also need to be updated.
- Redoing Program.cs:
- Replace DefaultKestrelRunner with BaseKestrelRunner (for DefaultHttpSysRunner - BaseHttpSysRunner)
- If you used AddOnStartAction / AddOnStopAction extension methods, then you need to connect the ViennaNET.WebApi.Runners.Extensions package
- We redo the configuration file:
- Remove unnecessary parameters from the webApiConfiguration section: logRequests and swaggerSubmit
- If you want to use the dynamic search for SimpleInjector packages, as is happening now, you need to add a section:
"simpleInjector": {
"loadPackagesDynamically": true
},
The loadPackagesDynamically flag is responsible for enabling automatic loading of packages from all assemblies that are at the root of the application folder, so that all dependencies get to the application folder, you need to add the parameter to the service project file:
<PropertyGroup>
<CopyLocalLockFileAssemblies> true </CopyLocalLockFileAssemblies>
</PropertyGroup>
By default, the flag is considered set to false, which means that all dependencies must be connected explicitly manually, using the extension method for the container from the ViennaNET.SimpleInjector.Extensions assembly in the root service package, for example:
container.AddPackage(new DiagnosingPackage())
.AddPackage(new RabbitMqPackage())
.AddPackage(new MessagingPackage())
In this case, there is no need to use the CopyLocalLockFileAssemblies parameter 7. The swagger enable flag has been moved from the webApiConfiguration section to the swagger section with the renaming swaggerSubmit -> useSwagger
"swagger": {
"useSwagger": true,
...
},
- If you used HttpClients through the ViennaNET.WebApi.Configurators.HttpClients.Jwt/Ntlm assemblies, you need to add a parameter with an authentication type to the section of each webApiEndpoints:
"webApiEndpoints": [
...
{
...
"authType": "jwt"
},
{
...
"authType": "ntlm"
},
...
],
Case II. The service was built manually (without using DefaultKestrelRunner or DefaultHttpSysRunner)
- In all assemblies using netcoreapp2.2, change to net6.0.
- Assemblies with configurators were renamed to ViennaNET.WebApi.Configurators.*, As well as some of them were merged or divided, so you need to familiarize yourself with their description and select the ones you need.
Example:
return CompanyHostBuilder.Create()
.UseKestrel()
.UseCommonModule()
.UseSimpleInjector()
.UseSwaggerWithJwtAuth()
.UseDiagnosing()
.UseJwtHttpClients()
.UseJwtAuth();
- We update versions of Company libraries to (2. *.*) In all assemblies. Version conflicts with third-party libraries (for example, SimpleInjector) may occur, so they need to be synchronized.
MVP Company.Framework on NET Core 2.2