Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / untmp / whidbey / QFE / ndp / fx / src / xsp / System / Web / ImpersonationContext.cs / 4 / ImpersonationContext.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web { using System; using System.Runtime.InteropServices; using System.Security.Permissions; using System.Web.Configuration; using System.Web.Hosting; using System.Web.Util; internal class ImpersonationContext : IDisposable { private HandleRef _savedToken; private bool _reverted; private bool _impersonating; // arg-less ctor creates dummy context internal ImpersonationContext() { } // ctor that takes a token impersonates that token internal ImpersonationContext(IntPtr token) { ImpersonateToken(new HandleRef(this, token)); } // IDisposable pattern ~ImpersonationContext() { Dispose(false); } void IDisposable.Dispose() { Undo(); } private void Dispose(bool disposing) { if (_savedToken.Handle != IntPtr.Zero) { try {} finally { UnsafeNativeMethods.CloseHandle(_savedToken.Handle); _savedToken = new HandleRef(this, IntPtr.Zero); } } } // impersonate a given token protected void ImpersonateToken(HandleRef token) { try { // first revert _savedToken = new HandleRef(this, GetCurrentToken()); if (_savedToken.Handle != IntPtr.Zero) { if (UnsafeNativeMethods.RevertToSelf() != 0) { _reverted = true; } } // impersonate token if not zero if (token.Handle != IntPtr.Zero) { if (UnsafeNativeMethods.SetThreadToken(IntPtr.Zero, token.Handle) == 0) { throw new HttpException(SR.GetString(SR.Cannot_impersonate)); } _impersonating = true; } } catch { RestoreImpersonation(); throw; } } // restore impersonation to the original state private void RestoreImpersonation() { // first revert before reimpersonating if (_impersonating) { UnsafeNativeMethods.RevertToSelf(); _impersonating = false; } // second reimpersonate the orignal saved identity (if exists) if (_savedToken.Handle != IntPtr.Zero) { if (_reverted) { if (UnsafeNativeMethods.SetThreadToken(IntPtr.Zero, _savedToken.Handle) == 0) { throw new HttpException(SR.GetString(SR.Cannot_impersonate)); } } _reverted = false; } } // 'public' version of Dispose internal void Undo() { RestoreImpersonation(); // free unmanaged resources Dispose(true); System.GC.SuppressFinalize(this); } // helper to get the currently impersonated token private static IntPtr GetCurrentToken() { IntPtr token = IntPtr.Zero; if (UnsafeNativeMethods.OpenThreadToken( UnsafeNativeMethods.GetCurrentThread(), UnsafeNativeMethods.TOKEN_READ | UnsafeNativeMethods.TOKEN_IMPERSONATE, true, ref token) == 0) { // if the last error is ERROR_NO_TOKEN it is ok, otherwise throw if (Marshal.GetLastWin32Error() != UnsafeNativeMethods.ERROR_NO_TOKEN) { throw new HttpException(SR.GetString(SR.Cannot_impersonate)); } } return token; } // helper to internal static bool CurrentThreadTokenExists { get { bool impersonating = false; try {} finally { IntPtr token = GetCurrentToken(); if (token != IntPtr.Zero) { impersonating = true; UnsafeNativeMethods.CloseHandle(token); } } return impersonating; } } } internal sealed class ProcessImpersonationContext : ImpersonationContext { internal ProcessImpersonationContext() { ImpersonateToken(new HandleRef(this, IntPtr.Zero)); } } internal sealed class ApplicationImpersonationContext : ImpersonationContext { internal ApplicationImpersonationContext() { ImpersonateToken(new HandleRef(this, HostingEnvironment.ApplicationIdentityToken)); } } internal sealed class ClientImpersonationContext : ImpersonationContext { internal ClientImpersonationContext(HttpContext context) { Start(context, true); } internal ClientImpersonationContext(HttpContext context, bool throwOnError) { Start(context, throwOnError); } private void Start(HttpContext context, bool throwOnError) { IntPtr token = IntPtr.Zero; try { if (context != null) { token = context.ImpersonationToken; } else { // by default use app identity token = HostingEnvironment.ApplicationIdentityToken; } } catch { if (throwOnError) { throw; } } // only impersonate if there is a token // this is to optimize for the default case of impersonation="false" // and no UNC identity, when requests run under process identity if (token != IntPtr.Zero) { ImpersonateToken(new HandleRef(this, token)); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- IFlowDocumentViewer.cs
- AnnotationAuthorChangedEventArgs.cs
- WebPartCatalogAddVerb.cs
- IntSecurity.cs
- Debugger.cs
- MediaScriptCommandRoutedEventArgs.cs
- XmlEntityReference.cs
- ColorTypeConverter.cs
- Bidi.cs
- TargetControlTypeAttribute.cs
- SecurityRuntime.cs
- ProcessRequestArgs.cs
- HierarchicalDataBoundControl.cs
- ImageListImage.cs
- Rotation3D.cs
- OracleSqlParser.cs
- NameTable.cs
- SoapReflectionImporter.cs
- DataGridViewCellEventArgs.cs
- MainMenu.cs
- SqlDataSourceFilteringEventArgs.cs
- SafeHandles.cs
- InstanceDescriptor.cs
- DocumentSequence.cs
- VisualBrush.cs
- Oid.cs
- EntityDataSourceDataSelection.cs
- connectionpool.cs
- ModuleConfigurationInfo.cs
- ElasticEase.cs
- BoundPropertyEntry.cs
- TextElementCollection.cs
- UnsafeMethods.cs
- ClientBuildManager.cs
- EditingCommands.cs
- PropertyStore.cs
- FormViewDeleteEventArgs.cs
- RequestStatusBarUpdateEventArgs.cs
- MasterPageCodeDomTreeGenerator.cs
- GeometryValueSerializer.cs
- HwndStylusInputProvider.cs
- Substitution.cs
- IRCollection.cs
- SafeLocalMemHandle.cs
- PasswordDeriveBytes.cs
- ECDsaCng.cs
- AssociatedControlConverter.cs
- OneOfScalarConst.cs
- MediaTimeline.cs
- TableLayoutSettingsTypeConverter.cs
- Misc.cs
- ServiceModelActivity.cs
- DesignerTransaction.cs
- CaseCqlBlock.cs
- TemplatedMailWebEventProvider.cs
- DataReaderContainer.cs
- OleDbError.cs
- PathSegmentCollection.cs
- DragDropHelper.cs
- MatrixConverter.cs
- Config.cs
- xmlglyphRunInfo.cs
- DictionaryBase.cs
- FileChangesMonitor.cs
- StrongNameKeyPair.cs
- ArrayTypeMismatchException.cs
- SqlInternalConnection.cs
- ConfigurationStrings.cs
- _ReceiveMessageOverlappedAsyncResult.cs
- BasicDesignerLoader.cs
- Axis.cs
- Point.cs
- xml.cs
- ElementHostPropertyMap.cs
- SafeFileMapViewHandle.cs
- xamlnodes.cs
- StreamUpgradeAcceptor.cs
- SqlCacheDependencyDatabase.cs
- EmptyStringExpandableObjectConverter.cs
- SystemIcons.cs
- InfiniteIntConverter.cs
- SerializationTrace.cs
- ProviderManager.cs
- AsyncPostBackErrorEventArgs.cs
- _UriSyntax.cs
- RegexCompiler.cs
- PixelShader.cs
- EntityTypeEmitter.cs
- FunctionDetailsReader.cs
- _SpnDictionary.cs
- AssemblyInfo.cs
- StatusBarItemAutomationPeer.cs
- Propagator.JoinPropagator.cs
- WeakReadOnlyCollection.cs
- Vector3DAnimationUsingKeyFrames.cs
- CharacterString.cs
- AddInActivator.cs
- EdmSchemaError.cs
- TransformationRules.cs
- SetUserLanguageRequest.cs