Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / wpf / src / Base / MS / Internal / Security / RightsManagement / SafeRightsManagementQueryHandle.cs / 1 / 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
- Control.cs
- XmlSerializableWriter.cs
- ModelVisual3D.cs
- DataAdapter.cs
- XhtmlBasicControlAdapter.cs
- XmlChildEnumerator.cs
- EntityDataSourceStatementEditorForm.cs
- PriorityRange.cs
- LoadedEvent.cs
- ExpressionDumper.cs
- XmlSchemaSequence.cs
- DataGridState.cs
- ObjectDisposedException.cs
- DrawingCollection.cs
- EmptyReadOnlyDictionaryInternal.cs
- HttpClientCertificate.cs
- HandoffBehavior.cs
- ComEventsMethod.cs
- DesignerSerializationManager.cs
- ContextMenuStrip.cs
- X509DefaultServiceCertificateElement.cs
- Unit.cs
- PageContentCollection.cs
- XmlElementAttribute.cs
- SignedXml.cs
- SecurityCriticalDataForSet.cs
- DateTimeOffsetConverter.cs
- SqlBuffer.cs
- RepeaterItemCollection.cs
- RtfControls.cs
- ScriptModule.cs
- LifetimeServices.cs
- ManualResetEvent.cs
- SystemSounds.cs
- MetadataProperty.cs
- ErrorsHelper.cs
- Inflater.cs
- OracleDataAdapter.cs
- NameTable.cs
- IntSecurity.cs
- CodeDOMUtility.cs
- ObjectHelper.cs
- Socket.cs
- ArgumentException.cs
- _emptywebproxy.cs
- PartitionResolver.cs
- ConversionContext.cs
- ReflectionPermission.cs
- CodeMemberProperty.cs
- HealthMonitoringSection.cs
- ProcessThread.cs
- TextTreeInsertElementUndoUnit.cs
- Stream.cs
- XmlQueryTypeFactory.cs
- HtmlSelect.cs
- RootProjectionNode.cs
- ObjectStateEntry.cs
- InvokePattern.cs
- XsltArgumentList.cs
- SelectionRangeConverter.cs
- ValidationRuleCollection.cs
- ComPlusDiagnosticTraceRecords.cs
- pingexception.cs
- SafeNativeMethods.cs
- SapiRecoInterop.cs
- ColorComboBox.cs
- Missing.cs
- TextParaClient.cs
- GraphicsContainer.cs
- SqlConnectionFactory.cs
- SchemaElementDecl.cs
- TemplateParser.cs
- SynchronousChannel.cs
- DataTemplate.cs
- BaseResourcesBuildProvider.cs
- HiddenFieldPageStatePersister.cs
- AnnotationStore.cs
- QuaternionAnimation.cs
- HtmlInputRadioButton.cs
- JsonEnumDataContract.cs
- WebPartConnectionCollection.cs
- TraceShell.cs
- BoundColumn.cs
- DataGridTableCollection.cs
- DesignRelationCollection.cs
- MsmqMessage.cs
- TabControl.cs
- TemplateNameScope.cs
- DbCommandDefinition.cs
- JsonUriDataContract.cs
- RadioButton.cs
- DataServiceQueryContinuation.cs
- SoapSchemaImporter.cs
- CompilerErrorCollection.cs
- EventNotify.cs
- ArrangedElement.cs
- AssertFilter.cs
- SqlMethodCallConverter.cs
- OperatorExpressions.cs
- Pen.cs