Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / xsp / System / Web / Util / Transactions.cs / 1 / Transactions.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * Transactions support for ASP.NET pages * * Copyright (c) 2000, Microsoft Corporation */ namespace System.Web.Util { using System.Collections; using System.EnterpriseServices; using System.Security.Permissions; // // Delegate to the transacted managed code // ////// public delegate void TransactedCallback(); // // Delegate for the internal transacted execution // internal enum TransactedExecState { CommitPending = 0, AbortPending = 1, Error = 2 } internal delegate int TransactedExecCallback(); // return value 'int' for interop // // Utility class with to be called to do transactions // ///[To be supplied.] ////// [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public class Transactions { ///[To be supplied.] ////// public static void InvokeTransacted(TransactedCallback callback, TransactionOption mode) { bool aborted = false; InvokeTransacted(callback, mode, ref aborted); } ///[To be supplied.] ////// public static void InvokeTransacted(TransactedCallback callback, TransactionOption mode, ref bool transactionAborted) { // check for hosting permission even if no user code on the stack HttpRuntime.CheckAspNetHostingPermission(AspNetHostingPermissionLevel.Medium, SR.Transaction_not_supported_in_low_trust); bool executeWithoutTransaction = false; #if !FEATURE_PAL // FEATURE_PAL does not enable Transactions if (Environment.OSVersion.Platform != PlatformID.Win32NT || Environment.OSVersion.Version.Major <= 4) throw new PlatformNotSupportedException(SR.GetString(SR.RequiresNT)); #else // !FEATURE_PAL throw new NotImplementedException("ROTORTODO"); #endif // !FEATURE_PAL if (mode == TransactionOption.Disabled) executeWithoutTransaction = true; if (executeWithoutTransaction) { // bypass the transaction logic callback(); transactionAborted = false; return; } TransactedInvocation call = new TransactedInvocation(callback); TransactedExecCallback execCallback = new TransactedExecCallback(call.ExecuteTransactedCode); PerfCounters.IncrementCounter(AppPerfCounter.TRANSACTIONS_PENDING); int rc; try { rc = UnsafeNativeMethods.TransactManagedCallback(execCallback, (int)mode); } finally { PerfCounters.DecrementCounter(AppPerfCounter.TRANSACTIONS_PENDING); } // rethrow the expection originally caught in managed code if (call.Error != null) throw new HttpException(null, call.Error); PerfCounters.IncrementCounter(AppPerfCounter.TRANSACTIONS_TOTAL); if (rc == 1) { PerfCounters.IncrementCounter(AppPerfCounter.TRANSACTIONS_COMMITTED); transactionAborted = false; } else if (rc == 0) { PerfCounters.IncrementCounter(AppPerfCounter.TRANSACTIONS_ABORTED); transactionAborted = true; } else { throw new HttpException(SR.GetString(SR.Cannot_execute_transacted_code)); } } // Class with wrappers to ContextUtil that don't throw internal class Utils { private Utils() { } /* internal static String TransactionId { get { String id = null; try { id = ContextUtil.TransactionId.ToString(); } catch { } return id; } } */ internal static bool IsInTransaction { get { bool inTransaction = false; try { inTransaction = ContextUtil.IsInTransaction; } catch { } return inTransaction; } } internal static bool AbortPending { get { bool aborted = false; try { if (ContextUtil.MyTransactionVote == TransactionVote.Abort) aborted = true; } catch { } return aborted; } } } // Managed class encapsulating the transacted call internal class TransactedInvocation { private TransactedCallback _callback; private Exception _error; internal TransactedInvocation(TransactedCallback callback) { _callback = callback; } internal int ExecuteTransactedCode() { TransactedExecState state = TransactedExecState.CommitPending; try { _callback(); if (Transactions.Utils.AbortPending) state = TransactedExecState.AbortPending; } catch (Exception e) { _error = e; // remember exception to be rethrown back in managed code state = TransactedExecState.Error; } return (int)state; } internal Exception Error { get { return _error; } } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //[To be supplied.] ///// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * Transactions support for ASP.NET pages * * Copyright (c) 2000, Microsoft Corporation */ namespace System.Web.Util { using System.Collections; using System.EnterpriseServices; using System.Security.Permissions; // // Delegate to the transacted managed code // ////// public delegate void TransactedCallback(); // // Delegate for the internal transacted execution // internal enum TransactedExecState { CommitPending = 0, AbortPending = 1, Error = 2 } internal delegate int TransactedExecCallback(); // return value 'int' for interop // // Utility class with to be called to do transactions // ///[To be supplied.] ////// [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public class Transactions { ///[To be supplied.] ////// public static void InvokeTransacted(TransactedCallback callback, TransactionOption mode) { bool aborted = false; InvokeTransacted(callback, mode, ref aborted); } ///[To be supplied.] ////// public static void InvokeTransacted(TransactedCallback callback, TransactionOption mode, ref bool transactionAborted) { // check for hosting permission even if no user code on the stack HttpRuntime.CheckAspNetHostingPermission(AspNetHostingPermissionLevel.Medium, SR.Transaction_not_supported_in_low_trust); bool executeWithoutTransaction = false; #if !FEATURE_PAL // FEATURE_PAL does not enable Transactions if (Environment.OSVersion.Platform != PlatformID.Win32NT || Environment.OSVersion.Version.Major <= 4) throw new PlatformNotSupportedException(SR.GetString(SR.RequiresNT)); #else // !FEATURE_PAL throw new NotImplementedException("ROTORTODO"); #endif // !FEATURE_PAL if (mode == TransactionOption.Disabled) executeWithoutTransaction = true; if (executeWithoutTransaction) { // bypass the transaction logic callback(); transactionAborted = false; return; } TransactedInvocation call = new TransactedInvocation(callback); TransactedExecCallback execCallback = new TransactedExecCallback(call.ExecuteTransactedCode); PerfCounters.IncrementCounter(AppPerfCounter.TRANSACTIONS_PENDING); int rc; try { rc = UnsafeNativeMethods.TransactManagedCallback(execCallback, (int)mode); } finally { PerfCounters.DecrementCounter(AppPerfCounter.TRANSACTIONS_PENDING); } // rethrow the expection originally caught in managed code if (call.Error != null) throw new HttpException(null, call.Error); PerfCounters.IncrementCounter(AppPerfCounter.TRANSACTIONS_TOTAL); if (rc == 1) { PerfCounters.IncrementCounter(AppPerfCounter.TRANSACTIONS_COMMITTED); transactionAborted = false; } else if (rc == 0) { PerfCounters.IncrementCounter(AppPerfCounter.TRANSACTIONS_ABORTED); transactionAborted = true; } else { throw new HttpException(SR.GetString(SR.Cannot_execute_transacted_code)); } } // Class with wrappers to ContextUtil that don't throw internal class Utils { private Utils() { } /* internal static String TransactionId { get { String id = null; try { id = ContextUtil.TransactionId.ToString(); } catch { } return id; } } */ internal static bool IsInTransaction { get { bool inTransaction = false; try { inTransaction = ContextUtil.IsInTransaction; } catch { } return inTransaction; } } internal static bool AbortPending { get { bool aborted = false; try { if (ContextUtil.MyTransactionVote == TransactionVote.Abort) aborted = true; } catch { } return aborted; } } } // Managed class encapsulating the transacted call internal class TransactedInvocation { private TransactedCallback _callback; private Exception _error; internal TransactedInvocation(TransactedCallback callback) { _callback = callback; } internal int ExecuteTransactedCode() { TransactedExecState state = TransactedExecState.CommitPending; try { _callback(); if (Transactions.Utils.AbortPending) state = TransactedExecState.AbortPending; } catch (Exception e) { _error = e; // remember exception to be rethrown back in managed code state = TransactedExecState.Error; } return (int)state; } internal Exception Error { get { return _error; } } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.[To be supplied.] ///
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ResourceReader.cs
- ItemsChangedEventArgs.cs
- MimeTypeAttribute.cs
- HttpCachePolicy.cs
- WebServiceResponseDesigner.cs
- DecoderFallbackWithFailureFlag.cs
- MachineSettingsSection.cs
- TraceSource.cs
- ArraySortHelper.cs
- ToolStripLabel.cs
- NullableFloatAverageAggregationOperator.cs
- XPathExpr.cs
- InputLangChangeEvent.cs
- ListMarkerSourceInfo.cs
- ConfigXmlText.cs
- ServiceHttpModule.cs
- GifBitmapEncoder.cs
- SmuggledIUnknown.cs
- ServiceOperationParameter.cs
- ModelUIElement3D.cs
- MessageDescriptionCollection.cs
- SplineKeyFrames.cs
- CatalogZoneBase.cs
- ItemCheckEvent.cs
- DrawingAttributes.cs
- basemetadatamappingvisitor.cs
- documentsequencetextpointer.cs
- NumberFormatInfo.cs
- WebService.cs
- DependencyObjectCodeDomSerializer.cs
- Dictionary.cs
- KeyNameIdentifierClause.cs
- SHA256Cng.cs
- ShapeTypeface.cs
- AcceleratedTokenAuthenticator.cs
- IQueryable.cs
- AssociatedControlConverter.cs
- AsynchronousChannelMergeEnumerator.cs
- RoleManagerSection.cs
- configsystem.cs
- StrokeCollection.cs
- SspiSecurityTokenParameters.cs
- TemplateComponentConnector.cs
- ProviderMetadataCachedInformation.cs
- RelationshipDetailsRow.cs
- SoapSchemaExporter.cs
- ContentPlaceHolder.cs
- FaultDesigner.cs
- _SSPISessionCache.cs
- _LocalDataStoreMgr.cs
- ResolveResponse.cs
- RegisteredArrayDeclaration.cs
- FixedElement.cs
- PenThread.cs
- ObjectHandle.cs
- BitSet.cs
- listitem.cs
- IndexerReference.cs
- InternalRelationshipCollection.cs
- CheckBoxFlatAdapter.cs
- WebCategoryAttribute.cs
- LocatorBase.cs
- Compiler.cs
- MimeBasePart.cs
- FullTextState.cs
- List.cs
- PolicyLevel.cs
- ClusterSafeNativeMethods.cs
- ReferencedType.cs
- ResourceProperty.cs
- RtfToXamlLexer.cs
- EntityWrapper.cs
- MetadataSet.cs
- ModelVisual3D.cs
- CodeCatchClauseCollection.cs
- ParsedAttributeCollection.cs
- documentsequencetextpointer.cs
- RoutedEventArgs.cs
- PageAdapter.cs
- APCustomTypeDescriptor.cs
- StackBuilderSink.cs
- ResourceReader.cs
- CompiledQuery.cs
- CatalogPartCollection.cs
- MailDefinition.cs
- Section.cs
- TextServicesCompartmentEventSink.cs
- XamlReader.cs
- ValueTypePropertyReference.cs
- PackageRelationshipCollection.cs
- controlskin.cs
- TableLayoutColumnStyleCollection.cs
- DeferredSelectedIndexReference.cs
- ExpressionNode.cs
- SudsCommon.cs
- EpmCustomContentDeSerializer.cs
- LinqDataSourceContextData.cs
- sqlinternaltransaction.cs
- StoragePropertyMapping.cs
- HostingEnvironmentWrapper.cs