Shuttle.Core.TransactionScope 20.0.0

Prefix Reserved
dotnet add package Shuttle.Core.TransactionScope --version 20.0.0                
NuGet\Install-Package Shuttle.Core.TransactionScope -Version 20.0.0                
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="Shuttle.Core.TransactionScope" Version="20.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Shuttle.Core.TransactionScope --version 20.0.0                
#r "nuget: Shuttle.Core.TransactionScope, 20.0.0"                
#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 Shuttle.Core.TransactionScope as a Cake Addin
#addin nuget:?package=Shuttle.Core.TransactionScope&version=20.0.0

// Install Shuttle.Core.TransactionScope as a Cake Tool
#tool nuget:?package=Shuttle.Core.TransactionScope&version=20.0.0                

Shuttle.Core.TransactionScope

PM> Install-Package Shuttle.Core.TransactionScope

This package makes use of the .Net TransactionScope class to provide ambient transaction handling.

Configuration

The relevant components may be configured using IServiceColletion:

services.AddTransactionScope(builder => 
{
    builder.Options.Enabled = true;
    builder.Options.IsolationLevel = isolationLevel;
    builder.Options.Timeout = TimeSpan.FromSeconds(30);
});

The default JSON settings structure is as follows::

{
	"Shuttle": {
		"TransactionScope": {
			"Enabled": true,
			"IsolationLevel": "isolation-level",
			"Timeout": "00:00:30"
		} 
	}
}

ITransactionScope

An implementation of the ITransactionScope interface is used to wrap a TransactionScope.

The DefaultTransactionScope makes use of the standard .NET TransactionScope functionality. There is also a NullTransactionScope, which is used when the transaction scope handling is disabled, that implements the null pattern so it implements the interface but does not do anything.

Properties

Guid Id { get; }

Returns the Id of the transaction scope.

Methods

void Complete();

Marks the transaction scope as complete.

ITransactionScopeFactory

An implementation of the ITransactionScopeFactory interface provides instances of an ITransactionScope implementation.

The TransactionScopeFactory provides a DefaultTransactionScope instance if transaction scopes are Enabled; else a NullTransactionScope that implements the null pattern.

Create

ITransactionScope Create(IsolationLevel isolationLevel, TimeSpan timeout);

Creates the relevant instance using the given parameters.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on Shuttle.Core.TransactionScope:

Package Downloads
Shuttle.Esb

Contains the core Shuttle.Esb assembly that should always be referenced when building Shuttle.Esb solutions.

Shuttle.Core.PipelineTransactionScope

Provides a mechanism to create a transaction scope when a pipeline stage starts.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
20.0.0 378 2/2/2025
11.1.0 1,660 8/5/2024