Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Base / MS / Internal / Security / RightsManagement / SafeRightsManagementQueryHandle.cs / 1305600 / SafeRightsManagementQueryHandle.cs
//------------------------------------------------------------------------------ // //// Copyright (c) Microsoft Corporation. All rights reserved. // // // Description: // SafeRightsManagementQueryHandle class // // History: // 10/12/2005: SarjanaS: Initial implementation. // //----------------------------------------------------------------------------- using System; using System.Runtime.InteropServices; using Microsoft.Win32.SafeHandles; using System.Security; namespace MS.Internal.Security.RightsManagement { [SecurityCritical(SecurityCriticalScope.Everything)] internal sealed class SafeRightsManagementQueryHandle : SafeHandle { //Although it is not obvious this constructor is being called by the interop services // it throws exceptions without it private SafeRightsManagementQueryHandle() : base(IntPtr.Zero, true) { } // We have incompatibility between SafeHandle class hierarchy and the unmanaged // DRM SDK declarations. In the safe handle hierarchy it is assumed that the type // of handle is the IntPtr (64 or 32 bit depending on the platform). In the unmanaged // SDK C++ unsigned long type is used, which is 32 bit regardless of the platform. // We have decided the safest thing would be to still use the SafeHandle classes // and subclasses and cast variable back and force under assumption that IntPtr // is at least as big as unsigned long (in the managed code we generally use uint // declaration for that) internal SafeRightsManagementQueryHandle(uint handle) : base((IntPtr)handle, true) // "true" means "owns the handle" { } // base class expects us to override this method with the handle specific release code protected override bool ReleaseHandle() { int z = 0; if (!IsInvalid) { // we can not use safe handle in the DrmClose... function // as the SafeHandle implementation marks this instance as an invalid by the time // ReleaseHandle is called. After that marshalling code doesn't let the current instance // of the Safe*Handle sub-class to cross managed/unmanaged boundary. z = SafeNativeMethods.DRMCloseQueryHandle((uint)this.handle); #if DEBUG Errors.ThrowOnErrorCode(z); #endif // This member might be called twice(depending on the client app). In order to // prevent Unmanaged RM SDK from returning an error (Handle is already closed) // we need to mark our handle as invalid after successful close call base.SetHandle(IntPtr.Zero); } return (z>=0); } // apparently there is no existing implementation that treats Zero and only Zero as an invalid value // so we are sub-classing the base class and we need to override the IsInvalid property along with // ReleaseHandle implementation public override bool IsInvalid { get { return this.handle.Equals(IntPtr.Zero); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // //// Copyright (c) Microsoft Corporation. All rights reserved. // // // Description: // SafeRightsManagementQueryHandle class // // History: // 10/12/2005: SarjanaS: Initial implementation. // //----------------------------------------------------------------------------- using System; using System.Runtime.InteropServices; using Microsoft.Win32.SafeHandles; using System.Security; namespace MS.Internal.Security.RightsManagement { [SecurityCritical(SecurityCriticalScope.Everything)] internal sealed class SafeRightsManagementQueryHandle : SafeHandle { //Although it is not obvious this constructor is being called by the interop services // it throws exceptions without it private SafeRightsManagementQueryHandle() : base(IntPtr.Zero, true) { } // We have incompatibility between SafeHandle class hierarchy and the unmanaged // DRM SDK declarations. In the safe handle hierarchy it is assumed that the type // of handle is the IntPtr (64 or 32 bit depending on the platform). In the unmanaged // SDK C++ unsigned long type is used, which is 32 bit regardless of the platform. // We have decided the safest thing would be to still use the SafeHandle classes // and subclasses and cast variable back and force under assumption that IntPtr // is at least as big as unsigned long (in the managed code we generally use uint // declaration for that) internal SafeRightsManagementQueryHandle(uint handle) : base((IntPtr)handle, true) // "true" means "owns the handle" { } // base class expects us to override this method with the handle specific release code protected override bool ReleaseHandle() { int z = 0; if (!IsInvalid) { // we can not use safe handle in the DrmClose... function // as the SafeHandle implementation marks this instance as an invalid by the time // ReleaseHandle is called. After that marshalling code doesn't let the current instance // of the Safe*Handle sub-class to cross managed/unmanaged boundary. z = SafeNativeMethods.DRMCloseQueryHandle((uint)this.handle); #if DEBUG Errors.ThrowOnErrorCode(z); #endif // This member might be called twice(depending on the client app). In order to // prevent Unmanaged RM SDK from returning an error (Handle is already closed) // we need to mark our handle as invalid after successful close call base.SetHandle(IntPtr.Zero); } return (z>=0); } // apparently there is no existing implementation that treats Zero and only Zero as an invalid value // so we are sub-classing the base class and we need to override the IsInvalid property along with // ReleaseHandle implementation public override bool IsInvalid { get { return this.handle.Equals(IntPtr.Zero); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- RequestResizeEvent.cs
- CommandManager.cs
- XpsDigitalSignature.cs
- StylusTouchDevice.cs
- CngProvider.cs
- ReadOnlyCollection.cs
- DataGridViewRow.cs
- XmlExtensionFunction.cs
- DataServiceConfiguration.cs
- WebResourceAttribute.cs
- HttpWebRequestElement.cs
- FactoryRecord.cs
- DragCompletedEventArgs.cs
- BitmapEffectGroup.cs
- CustomAttribute.cs
- CapabilitiesState.cs
- Light.cs
- HttpHostedTransportConfiguration.cs
- TextEndOfSegment.cs
- CollectionBase.cs
- DTCTransactionManager.cs
- DebugViewWriter.cs
- Ops.cs
- HttpDebugHandler.cs
- ThreadStartException.cs
- ModifiableIteratorCollection.cs
- xmlglyphRunInfo.cs
- SqlDeflator.cs
- CodeMethodMap.cs
- DeferredBinaryDeserializerExtension.cs
- Input.cs
- ICollection.cs
- ControlLocalizer.cs
- MetadataPropertyCollection.cs
- WebPartMenu.cs
- DocumentXPathNavigator.cs
- DocumentViewerAutomationPeer.cs
- SQLInt32Storage.cs
- SingleBodyParameterMessageFormatter.cs
- HttpServerUtilityBase.cs
- SemanticResultValue.cs
- SqlTrackingWorkflowInstance.cs
- StrokeIntersection.cs
- nulltextnavigator.cs
- SemanticAnalyzer.cs
- assemblycache.cs
- AudioSignalProblemOccurredEventArgs.cs
- CapabilitiesAssignment.cs
- TypeTypeConverter.cs
- IgnoreSectionHandler.cs
- ToolStripItemDesigner.cs
- XmlDataDocument.cs
- RegexRunnerFactory.cs
- FixedFlowMap.cs
- Timeline.cs
- FormatVersion.cs
- WeakHashtable.cs
- StorageSetMapping.cs
- StylusPointProperty.cs
- Stack.cs
- ObjectAnimationUsingKeyFrames.cs
- BCryptNative.cs
- Pkcs9Attribute.cs
- XmlCollation.cs
- SqlBulkCopyColumnMappingCollection.cs
- ColorAnimationUsingKeyFrames.cs
- RenderDataDrawingContext.cs
- QilPatternFactory.cs
- ImageSource.cs
- ServicePointManagerElement.cs
- EmptyImpersonationContext.cs
- HelpKeywordAttribute.cs
- InstanceBehavior.cs
- UserControlParser.cs
- SyndicationDeserializer.cs
- GPRECT.cs
- BuildProvider.cs
- OracleException.cs
- UrlMappingsSection.cs
- MobileRedirect.cs
- TextServicesPropertyRanges.cs
- Logging.cs
- TextContainerHelper.cs
- HttpSysSettings.cs
- OracleLob.cs
- DnsPermission.cs
- JavaScriptSerializer.cs
- DbParameterCollectionHelper.cs
- PseudoWebRequest.cs
- SetStateEventArgs.cs
- CatalogPartDesigner.cs
- TemplateKeyConverter.cs
- WorkflowEventArgs.cs
- wmiprovider.cs
- Border.cs
- ComboBoxDesigner.cs
- CharacterHit.cs
- ApplicationManager.cs
- _SecureChannel.cs
- Point.cs