Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / 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
- WrapPanel.cs
- InputQueueChannel.cs
- CallContext.cs
- TextEmbeddedObject.cs
- StrokeCollection2.cs
- DataListItemEventArgs.cs
- MissingSatelliteAssemblyException.cs
- BitmapFrameDecode.cs
- DbConnectionStringBuilder.cs
- ResourceAssociationTypeEnd.cs
- SelectionUIHandler.cs
- BackgroundFormatInfo.cs
- COM2ColorConverter.cs
- FileIOPermission.cs
- FormViewDeletedEventArgs.cs
- WarningException.cs
- TerminatorSinks.cs
- RequestContext.cs
- XmlArrayItemAttribute.cs
- BypassElement.cs
- TrustManagerPromptUI.cs
- ReliableMessagingHelpers.cs
- ClockGroup.cs
- NamespaceList.cs
- DataSourceHelper.cs
- ModuleBuilder.cs
- Timer.cs
- SecUtil.cs
- QueryStringConverter.cs
- EndpointAddressAugust2004.cs
- DynamicMethod.cs
- WSSecurityTokenSerializer.cs
- BinaryParser.cs
- __Filters.cs
- XmlSchemaAttributeGroup.cs
- UnicodeEncoding.cs
- HttpCookie.cs
- ToolboxItemAttribute.cs
- ShapeTypeface.cs
- SafeTimerHandle.cs
- XmlException.cs
- TimeSpanConverter.cs
- DataGridColumnReorderingEventArgs.cs
- EntityDataSourceUtil.cs
- HttpException.cs
- SqlConnectionManager.cs
- TraceHandlerErrorFormatter.cs
- SafeRegistryHandle.cs
- OSFeature.cs
- ViewStateModeByIdAttribute.cs
- KeyValueConfigurationCollection.cs
- RijndaelManagedTransform.cs
- Recipient.cs
- ScriptControl.cs
- ReadOnlyTernaryTree.cs
- GeneralTransform.cs
- WebSysDefaultValueAttribute.cs
- XhtmlTextWriter.cs
- AppDomainProtocolHandler.cs
- _LazyAsyncResult.cs
- UpdatableWrapper.cs
- DataGridViewCellCollection.cs
- PathFigureCollectionConverter.cs
- GcSettings.cs
- MetabaseReader.cs
- ResourceReader.cs
- PolicyException.cs
- Sequence.cs
- SqlDataSourceQuery.cs
- xsdvalidator.cs
- IRCollection.cs
- HtmlControlPersistable.cs
- Scripts.cs
- transactioncontext.cs
- EntityConnectionStringBuilder.cs
- SchemaMapping.cs
- ListViewPagedDataSource.cs
- LinearKeyFrames.cs
- ChooseAction.cs
- ColorMap.cs
- DataBoundControlDesigner.cs
- XmlDataDocument.cs
- RegistrationProxy.cs
- ResourceContainer.cs
- PathGradientBrush.cs
- MimeReflector.cs
- ChannelDispatcherCollection.cs
- LinkUtilities.cs
- RelationalExpressions.cs
- XPathConvert.cs
- AlignmentYValidation.cs
- ActivityLocationReferenceEnvironment.cs
- RC2.cs
- ProfilePropertyMetadata.cs
- ScaleTransform3D.cs
- DeflateStream.cs
- MenuItemCollectionEditor.cs
- TreeNodeClickEventArgs.cs
- ContextMenu.cs
- ObjRef.cs