Xtensive.Orm.Reprocessing 7.1.3

There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package Xtensive.Orm.Reprocessing --version 7.1.3                
NuGet\Install-Package Xtensive.Orm.Reprocessing -Version 7.1.3                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Xtensive.Orm.Reprocessing" Version="7.1.3" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Xtensive.Orm.Reprocessing --version 7.1.3                
#r "nuget: Xtensive.Orm.Reprocessing, 7.1.3"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Xtensive.Orm.Reprocessing as a Cake Addin
#addin nuget:?package=Xtensive.Orm.Reprocessing&version=7.1.3

// Install Xtensive.Orm.Reprocessing as a Cake Tool
#tool nuget:?package=Xtensive.Orm.Reprocessing&version=7.1.3                

Xtensive.Orm.Reprocessing

Summary

The extension provides API for reprocessible operations. The reprocessible operation should represent a separate block of logic, usually a delegate of a method and be transactional.

Prerequisites

DataObjects.Net 7.1.x (http://dataobjects.net)

Examples of usage

Examples #1. Simple reprocessible operation looks like this:

  Domain.Execute(session => {
    // Task logic
  });

Expample #2. Usage of built-in reprocessing strategies.

There are 3 strategies that can be used for task execution:

  • HandleReprocessibleException strategy The strategy catches all reprocessible expections (deadlock and transaction serialization exceptions) and makes another attempt to execute the task
  • HandleUniqueConstraintViolation strategy The same as previous one but also catches unique constraint violation exception
  • NoReprocess strategy No reprocessing is provided

To indicate that a particular strategy should be used, use the following syntax:

  Domain.WithStrategy(new HandleReprocessExceptionStrategy())
    .Execute(session => {
      // Task logic
    });

Examples of how to configure extension

Following examples show different ways to configure extension in configuration files of various types.

Example #1 Confugure in App.config/Web.config

<configuration>
  <configSections>
    
    <section name="Xtensive.Orm.Reprocessing" 
      type="Xtensive.Orm.Reprocessing.Configuration.ConfigurationSection, Xtensive.Orm.Reprocessing" />
  </configSections>

  <Xtensive.Orm.Reprocessing 
    defaultTransactionOpenMode="New" 
    defaultExecuteStrategy="Xtensive.Orm.Reprocessing.HandleReprocessableExceptionStrategy, Xtensive.Orm.Reprocessing">
  </Xtensive.Orm.Reprocessing>
</configuration>

Such configuration is usually read with System.Configuration.ConfigurationManager. If project still supports such configurations then Reprocessing configuration will be read automatically when it needs to be read. Sometimes a work-around is needed to read such configuration, for more read Example #2 and Example #3

Example #2 Reading old-style configuration of an assembly in NET 5 and newer.

Due to new architecture without AppDomain (which among the other things was in charge of gathering configuration files of loaded assemblies as it would be one configuration file) System.Configuration.ConfigurationManager now reads only configuration file of actual executable, loaded assemblies' configuration files stay unreachable by default, though there is need to read some data from them. A great example is test projects which are usually get loaded by test runner executable, and the only configuration accessible in this case is test runner one.

Extra step is required to read configuration files in such cases. Thankfully, ConfigurationManager has methods to get access to assemblies' configuration files.

To get access to an assembly configuration file it should be opened explicitly by

  var configuration = ConfigurationManager.OpenExeConfiguration(typeof(SomeTypeInConfigOwnerAssembly).Assembly.Location);

The instance returned from OpenExeConfiguration provides access to sections of the assembly configuration. DataObjects.Net configurations (DomainConfiguration, ReprocessingConfiguration, etc.) have Load() methods that can recieve this instance. ReprocessingConfiguration can be read like so

  var configuration = ConfigurationManager.OpenExeConfiguration(typeof(SomeTypeInConfigOwnerAssembly).Assembly.Location);
  var reprocessingConfig = ReprocessingConfiguration.Load(configuration);

  // loaded configuration should be manually placed to
  domainConfiguration.ExtensionConfigurations.Set(reprocessingConfig);

The domainConfiguration.ExtensionConfigurations is a new unified place from which the extension will try to get its configuration instead of calling default parameterless Load() method, which has not a lot of sense now, though the method is kept as a second source for backwards compatibility.

For more convenience, DomainConfiguration extensions are provided, which make code more neater. For instance,

  var configuration = ConfigurationManager.OpenExeConfiguration(typeof(SomeTypeInConfigOwnerAssembly).Assembly.Location);

  // the extension hides getting configuration with ReprocessingConfiguration.Load(configuration)
  // and also putting it to ExtensionConfigurations collection.
  domainConfiguration.ConfigureReprocessingExtension(configuration);

Custom section names are also supported if for some reason default section name is not used.

Example #3 Reading old-style configuration of an assembly in a project that uses appsettings.json file.

If for some reason there is need to keep the old-style configuration then there is a work-around as well. Static configuration manager provides method OpenMappedExeConfiguration() which allows to get any *.config file as System.Configuration.Configuration instance. For example,

  ExeConfigurationFileMap configFileMap = new ExeConfigurationFileMap();
  configFileMap.ExeConfigFilename = "Orm.config"; //or other file name, the file should exist bin folder
  var configuration = System.Configuration.ConfigurationManager.OpenMappedExeConfiguration(configFileMap, ConfigurationUserLevel.None);

After that, as in previous example, the instance can be passed to Load method of ReprocessingConfiguration to read extension configuration and later put it to DomainConfiguration.ExtensionConfigurations

  var reprocessingConfiguration = ReprocessingConfiguration.Load(configuration);

  domainConfiguration.ExtensionConfigurations.Set(reprocessingConfiguration);

Extension usage will look like

  domainConfiguration.ConfigureReprocessingExtension(configuration);

Example #4 Configure using Microsoft.Extensions.Configuration API.

This API allows to have configurations in various forms including JSON and XML formats. Loading of such files may differ depending on .NET version, check Microsoft manuals for instructions.

Allowed JSON and XML configuration definition look like below

<configuration>
  <Xtensive.Orm.Reprocessing>
    <DefaultTransactionOpenMode>New</DefaultTransactionOpenMode>
    <DefaultExecuteStrategy>Xtensive.Orm.Reprocessing.HandleReprocessableExceptionStrategy, Xtensive.Orm.Reprocessing</DefaultExecuteStrategy>
  </Xtensive.Orm.Reprocessing>
</configuration>
{
  "Xtensive.Orm.Reprocessing": {
    "DefaultTransactionOpenMode" : "New",
    "DefaultExecuteStrategy" : "Xtensive.Orm.Reprocessing.HandleReprocessableExceptionStrategy, Xtensive.Orm.Reprocessing"
  }
}

The API has certain issues with Xml elements with attributes so it is recommended to use more up-to-date attributeless nodes. For JSON it is pretty clear, almost averyone knows its format.

ReprocessingConfiguration.Load method can accept different types of abstractions from the API, including

  • Microsoft.Extensions.Configuration.IConfiguration;
  • Microsoft.Extensions.Configuration.IConfigurationRoot;
  • Microsoft.Extensions.Configuration.IConfigurationSection.

Loading of configuration may look like

  
  var app = builder.Build();

  //...

  // tries to load from default section "Xtensive.Orm.Reprocessing"
  var reprocessingConfig = ReprocessingConfiguration.Load(app.Configuration);

  domainConfiguration.ExtensionConfigurations.Set(reprocessingConfig);

or, with use of extension, like

  
  var app = builder.Build();

  //...

  // tries to load from default section "Xtensive.Orm.Reprocessing"
  // and put it into domainConfiguration.ExtensionConfigurations

  domainConfiguration.ConfigureReprocessingExtension(app.Configuration);

Example #5 Configure using Microsoft.Extensions.Configuration API from section with non-default name.

For configurations like

<configuration>
  <Orm.Reprocessing>
    <DefaultTransactionOpenMode>New</DefaultTransactionOpenMode>
    <DefaultExecuteStrategy>Xtensive.Orm.Reprocessing.HandleReprocessableExceptionStrategy, Xtensive.Orm.Reprocessing</DefaultExecuteStrategy>
  </Orm.Reprocessing>
</configuration>
{
  "Orm.Reprocessing": {
    "DefaultTransactionOpenMode" : "New",
    "DefaultExecuteStrategy" : "Xtensive.Orm.Reprocessing.HandleReprocessableExceptionStrategy, Xtensive.Orm.Reprocessing"
  }
}

Loading of configuration may look like

  
  var app = builder.Build();

  //...

  var reprocessingConfig = ReprocessingConfiguration.Load(app.Configuration, "Orm.Reprocessing");

  domainConfiguration.ExtensionConfigurations.Set(reprocessingConfig);

or, with use of extension, like

  
  var app = builder.Build();

  //...

  domainConfiguration.ConfigureReprocessingExtension(app.Configuration, "Orm.Reprocessing");

Example #6 Configure using Microsoft.Extensions.Configuration API from sub-section deeper in section tree.

If for some reason extension configuration should be moved deeper in section tree like something below

<configuration>
  <Orm.Extensions>
    <Xtensive.Orm.Reprocessing>
      <DefaultTransactionOpenMode>New</DefaultTransactionOpenMode>
      <DefaultExecuteStrategy>Xtensive.Orm.Reprocessing.HandleReprocessableExceptionStrategy, Xtensive.Orm.Reprocessing</DefaultExecuteStrategy>
    </Xtensive.Orm.Reprocessing>
  </Orm.Extensions>
</configuration>

or in JSON

{
  "Orm.Extensions": {
    "Xtensive.Orm.Reprocessing": {
      "DefaultTransactionOpenMode" : "New",
      "DefaultExecuteStrategy" : "Xtensive.Orm.Reprocessing.HandleReprocessableExceptionStrategy, Xtensive.Orm.Reprocessing"
    }
  }
}

Then section must be provided manually, code may look like

  
  var app = builder.Build();

  //...

  var configurationRoot = app.Configuration;
  var extensionsGroupSection = configurationRoot.GetSection("Orm.Extensions");
  var reprocessingSection = extensionsGroupSection.GetSection("Xtensive.Orm.Reprocessing");

  var reprocessingConfig = ReprocessingConfiguration.Load(reprocessingSection);

  domainConfiguration.ExtensionConfigurations.Set(reprocessingConfig);

or, with use of extension method, like

  
  var app = builder.Build();

  //...

  var configurationRoot = app.Configuration;
  var extensionsGroupSection = configurationRoot.GetSection("Orm.Extensions");
  var reprocessingSection = extensionsGroupSection.GetSection("Xtensive.Orm.Reprocessing");

  domainConfiguration.ConfigureReprocessingExtension(reprocessingSection);
Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
7.2.0-Beta-1 137 12/28/2023
7.1.3 76 12/24/2024
7.1.2 134 10/18/2024
7.1.1 10,439 11/14/2023
7.1.0 332 4/12/2023
7.1.0-RC 115 3/9/2023
7.1.0-Beta-2 131 12/19/2022
7.1.0-Beta-1 146 7/4/2022
7.0.6 87 12/19/2024
7.0.5 91 6/3/2024
7.0.4 120 11/12/2023
7.0.3 540 3/21/2022
7.0.2 481 2/8/2022
7.0.1 381 10/29/2021
7.0.0 390 6/2/2021
6.0.14 86 12/17/2024
6.0.13 135 4/4/2024
6.0.12 16,160 11/10/2023
6.0.11 466 1/12/2023
6.0.10 471 4/29/2022
6.0.9 497 2/2/2022
6.0.8 431 10/28/2021
6.0.7 51,177 8/27/2021
6.0.6 409 5/24/2021
6.0.5 626 3/9/2021
6.0.4 12,262 12/22/2020
6.0.3 601 9/29/2020
6.0.0 1,189 1/28/2020
5.1.0-Beta-1 938 1/30/2015
5.0.24 403 4/27/2021
5.0.23 450 2/4/2021
5.0.22 587 11/18/2020
5.0.21 504 11/6/2020
5.0.20 646 12/25/2019
5.0.19 17,853 5/30/2019
5.0.19-Beta-2 674 4/16/2019
5.0.19-Beta-1 559 12/29/2018
5.0.18 3,632 9/28/2018
5.0.18-Beta-3 682 7/2/2018
5.0.18-Beta-2 753 6/6/2018
5.0.18-Beta-1 799 4/24/2018
5.0.17 1,010 2/27/2018
5.0.17-Beta-3 777 2/12/2018
5.0.17-Beta-2 809 1/12/2018
5.0.17-Beta-1 780 12/28/2017
5.0.16 948 12/1/2017
5.0.16-Beta-1 711 9/27/2017
5.0.15 1,004 8/1/2017
5.0.14 1,018 6/19/2017
5.0.13 1,031 3/22/2017
5.0.12 1,036 2/14/2017
5.0.11 1,036 1/25/2017
5.0.11-RC2 768 12/16/2016
5.0.11-RC 1,092 9/20/2016
5.0.10 1,076 8/5/2016
5.0.10-RC 815 6/30/2016
5.0.9 1,089 3/3/2016
5.0.8 1,078 2/15/2016
5.0.7 1,081 1/27/2016
5.0.7-RC2 986 12/8/2015
5.0.7-RC 853 9/10/2015
5.0.6 1,188 7/3/2015
5.0.5 1,306 4/23/2015
5.0.4 1,122 3/19/2015
5.0.4-RC 1,278 2/25/2015
5.0.3 1,530 10/31/2014
5.0.2 1,156 9/11/2014
5.0.0 1,148 8/15/2014
5.0.0-RC2 950 8/1/2014
5.0.0-RC 883 7/21/2014
5.0.0-Beta-3 930 5/28/2014
5.0.0-Beta-2 1,006 2/28/2014
5.0.0-Beta-1 939 11/14/2013
4.6.9 1,115 7/3/2015
4.6.8 1,162 8/1/2014
4.6.7 1,220 6/23/2014
4.6.6 1,402 4/9/2014
4.6.5 1,218 1/7/2014
4.6.4 1,299 9/30/2013
4.6.3 1,357 2/4/2013
4.6.2 1,364 11/28/2012
4.6.0 1,476 10/11/2012
4.6.0-RC 1,175 10/4/2012
4.5.8 1,261 9/30/2013
4.5.7 1,262 2/4/2013
4.5.6 1,430 11/28/2012
4.5.5 1,393 10/11/2012
4.5.5-RC 1,102 10/4/2012
4.5.3 1,371 8/6/2012
4.5.2 1,450 5/10/2012
4.5.0 1,503 3/13/2012