Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Base / MS / Internal / Security / RightsManagement / SafeRightsManagementEnvironmentHandle.cs / 1305600 / SafeRightsManagementEnvironmentHandle.cs
//------------------------------------------------------------------------------ // //// Copyright (c) Microsoft Corporation. All rights reserved. // // // Description: // SafeRightsManagementEnvironmentHandle 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 SafeRightsManagementEnvironmentHandle : SafeHandle { //Although it is not obvious this constructor is being called by the interop services // it throws exceptions without it private SafeRightsManagementEnvironmentHandle() : 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 SafeRightsManagementEnvironmentHandle(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.DRMCloseEnvironmentHandle((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: // SafeRightsManagementEnvironmentHandle 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 SafeRightsManagementEnvironmentHandle : SafeHandle { //Although it is not obvious this constructor is being called by the interop services // it throws exceptions without it private SafeRightsManagementEnvironmentHandle() : 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 SafeRightsManagementEnvironmentHandle(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.DRMCloseEnvironmentHandle((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
- JoinTreeNode.cs
- CodeGeneratorAttribute.cs
- VersionPair.cs
- AnonymousIdentificationSection.cs
- TextRange.cs
- compensatingcollection.cs
- ConfigXmlWhitespace.cs
- Literal.cs
- EntityProviderFactory.cs
- GlyphShapingProperties.cs
- FormatPage.cs
- LocalizedNameDescriptionPair.cs
- BehaviorEditorPart.cs
- PassportAuthenticationModule.cs
- PropertyChangedEventManager.cs
- BindValidator.cs
- FormatterServices.cs
- Vector3D.cs
- XmlQueryTypeFactory.cs
- EntityDataSourceContextCreatingEventArgs.cs
- NativeMethods.cs
- IntSecurity.cs
- ActivityDesignerHighlighter.cs
- CachedCompositeFamily.cs
- ColumnBinding.cs
- FixedPage.cs
- CodeLabeledStatement.cs
- AdornerPresentationContext.cs
- ViewManager.cs
- TextBoxLine.cs
- BaseParaClient.cs
- OdbcEnvironment.cs
- SqlDataSourceCommandEventArgs.cs
- StructuredTypeEmitter.cs
- FlowDocumentView.cs
- StaticContext.cs
- FrameworkRichTextComposition.cs
- UIElementPropertyUndoUnit.cs
- SplitterDesigner.cs
- StylusTip.cs
- TypeLoadException.cs
- TabItemAutomationPeer.cs
- Identity.cs
- HttpModuleAction.cs
- DetailsViewActionList.cs
- DataBoundControlHelper.cs
- XmlSchemaAppInfo.cs
- InputLanguageProfileNotifySink.cs
- ServicePoint.cs
- InboundActivityHelper.cs
- AnnotationAdorner.cs
- NavigationProperty.cs
- DefaultBinder.cs
- ApplicationFileCodeDomTreeGenerator.cs
- Cursors.cs
- SequenceRange.cs
- ExecutionEngineException.cs
- Cell.cs
- SHA512Managed.cs
- EncoderNLS.cs
- XhtmlBasicCommandAdapter.cs
- DispatcherFrame.cs
- SingleAnimation.cs
- HMAC.cs
- XPathConvert.cs
- NativeMethods.cs
- ScrollPatternIdentifiers.cs
- SmiRecordBuffer.cs
- MergablePropertyAttribute.cs
- ToolStripProfessionalLowResolutionRenderer.cs
- FixedPageStructure.cs
- HMACSHA1.cs
- IChannel.cs
- ForAllOperator.cs
- ScriptComponentDescriptor.cs
- ViewPort3D.cs
- SelectedDatesCollection.cs
- WorkflowFileItem.cs
- LockedActivityGlyph.cs
- FileCodeGroup.cs
- WebBrowserDesigner.cs
- HttpMethodAttribute.cs
- MultipleViewProviderWrapper.cs
- Mouse.cs
- MetadataSource.cs
- CodeCompileUnit.cs
- IIS7WorkerRequest.cs
- DataServiceHostFactory.cs
- Rect.cs
- UnsafeNativeMethodsTablet.cs
- SpinLock.cs
- ButtonRenderer.cs
- SyntaxCheck.cs
- AsyncResult.cs
- DocumentPageView.cs
- StreamingContext.cs
- D3DImage.cs
- WrapPanel.cs
- SecurityKeyUsage.cs
- ExpressionNode.cs