SafeSecurityHandles.cs source code in C# .NET

Source code for the .NET framework in C#

                        

Code:

/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / clr / src / BCL / System / Security / SafeSecurityHandles.cs / 1305376 / SafeSecurityHandles.cs

                            // [....] 
namespace Microsoft.Win32.SafeHandles {
    using System;
    using System.Runtime.CompilerServices;
    using System.Runtime.InteropServices; 
    using System.Runtime.ConstrainedExecution;
    using System.Runtime.Versioning; 
    using System.Security; 

#if !FEATURE_PAL 
    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeLocalAllocHandle : SafeBuffer {
        private SafeLocalAllocHandle () : base(true) {}
 
        // 0 is an Invalid Handle
        internal SafeLocalAllocHandle (IntPtr handle) : base (true) { 
            SetHandle(handle); 
        }
 
        internal static SafeLocalAllocHandle InvalidHandle {
            get { return new SafeLocalAllocHandle(IntPtr.Zero); }
        }
 
        [System.Security.SecurityCritical]
        override protected bool ReleaseHandle() 
        { 
            return Win32Native.LocalFree(handle) == IntPtr.Zero;
        } 
    }

    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeLsaLogonProcessHandle : SafeHandleZeroOrMinusOneIsInvalid { 
        private SafeLsaLogonProcessHandle() : base (true) {}
 
        // 0 is an Invalid Handle 
        internal SafeLsaLogonProcessHandle(IntPtr handle) : base (true) {
            SetHandle(handle); 
        }

        internal static SafeLsaLogonProcessHandle InvalidHandle {
            get { return new SafeLsaLogonProcessHandle(IntPtr.Zero); } 
        }
 
        [System.Security.SecurityCritical] 
        override protected bool ReleaseHandle()
        { 
            // LsaDeregisterLogonProcess returns an NTSTATUS
            return Win32Native.LsaDeregisterLogonProcess(handle) >= 0;
        }
    } 

    [System.Security.SecurityCritical]  // auto-generated 
    internal sealed class SafeLsaMemoryHandle : SafeBuffer { 
        private SafeLsaMemoryHandle() : base(true) {}
 
        // 0 is an Invalid Handle
        internal SafeLsaMemoryHandle(IntPtr handle) : base (true) {
            SetHandle(handle);
        } 

        internal static SafeLsaMemoryHandle InvalidHandle { 
            get { return new SafeLsaMemoryHandle( IntPtr.Zero ); } 
        }
 
        [System.Security.SecurityCritical]
        override protected bool ReleaseHandle()
        {
            return Win32Native.LsaFreeMemory(handle) == 0; 
        }
    } 
 
    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeLsaPolicyHandle : SafeHandleZeroOrMinusOneIsInvalid { 
        private SafeLsaPolicyHandle() : base(true) {}

        // 0 is an Invalid Handle
        internal SafeLsaPolicyHandle(IntPtr handle) : base (true) { 
            SetHandle(handle);
        } 
 
        internal static SafeLsaPolicyHandle InvalidHandle {
            get { return new SafeLsaPolicyHandle( IntPtr.Zero ); } 
        }

        [System.Security.SecurityCritical]
        override protected bool ReleaseHandle() 
        {
            return Win32Native.LsaClose(handle) == 0; 
        } 
    }
 
    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeLsaReturnBufferHandle : SafeBuffer {
        private SafeLsaReturnBufferHandle() : base (true) {}
 
        // 0 is an Invalid Handle
        internal SafeLsaReturnBufferHandle(IntPtr handle) : base (true) { 
            SetHandle(handle); 
        }
 
        internal static SafeLsaReturnBufferHandle InvalidHandle {
            get { return new SafeLsaReturnBufferHandle(IntPtr.Zero); }
        }
 
        [System.Security.SecurityCritical]
        override protected bool ReleaseHandle() 
        { 
            // LsaFreeReturnBuffer returns an NTSTATUS
            return Win32Native.LsaFreeReturnBuffer(handle) >= 0; 
        }
    }

    [System.Security.SecurityCritical]  // auto-generated 
    internal sealed class SafeProcessHandle : SafeHandleZeroOrMinusOneIsInvalid {
        private SafeProcessHandle() : base (true) {} 
 
        // 0 is an Invalid Handle
        internal SafeProcessHandle(IntPtr handle) : base (true) { 
            SetHandle(handle);
        }

        internal static SafeProcessHandle InvalidHandle { 
            get { return new SafeProcessHandle(IntPtr.Zero); }
        } 
 
        [System.Security.SecurityCritical]
        [ResourceExposure(ResourceScope.None)] 
        [ResourceConsumption(ResourceScope.Machine, ResourceScope.Machine)]
        override protected bool ReleaseHandle()
        {
            return Win32Native.CloseHandle(handle); 
        }
    } 
 
    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeThreadHandle : SafeHandleZeroOrMinusOneIsInvalid { 
        private SafeThreadHandle() : base (true) {}

        // 0 is an Invalid Handle
        internal SafeThreadHandle(IntPtr handle) : base (true) { 
            SetHandle(handle);
        } 
 
        [System.Security.SecurityCritical]
        [ResourceExposure(ResourceScope.None)] 
        [ResourceConsumption(ResourceScope.Machine, ResourceScope.Machine)]
        override protected bool ReleaseHandle()
        {
            return Win32Native.CloseHandle(handle); 
        }
    } 
 
    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeTokenHandle : SafeHandleZeroOrMinusOneIsInvalid { 
        private SafeTokenHandle() : base (true) {}

        // 0 is an Invalid Handle
        internal SafeTokenHandle(IntPtr handle) : base (true) { 
            SetHandle(handle);
        } 
 
        internal static SafeTokenHandle InvalidHandle {
            get { return new SafeTokenHandle(IntPtr.Zero); } 
        }

        [System.Security.SecurityCritical]
        [ResourceExposure(ResourceScope.None)] 
        [ResourceConsumption(ResourceScope.Machine, ResourceScope.Machine)]
        override protected bool ReleaseHandle() 
        { 
            return Win32Native.CloseHandle(handle);
        } 
    }

#endif // !FEATURE_PAL
} 

// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// Copyright (c) Microsoft Corporation. All rights reserved.
// [....] 
namespace Microsoft.Win32.SafeHandles {
    using System;
    using System.Runtime.CompilerServices;
    using System.Runtime.InteropServices; 
    using System.Runtime.ConstrainedExecution;
    using System.Runtime.Versioning; 
    using System.Security; 

#if !FEATURE_PAL 
    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeLocalAllocHandle : SafeBuffer {
        private SafeLocalAllocHandle () : base(true) {}
 
        // 0 is an Invalid Handle
        internal SafeLocalAllocHandle (IntPtr handle) : base (true) { 
            SetHandle(handle); 
        }
 
        internal static SafeLocalAllocHandle InvalidHandle {
            get { return new SafeLocalAllocHandle(IntPtr.Zero); }
        }
 
        [System.Security.SecurityCritical]
        override protected bool ReleaseHandle() 
        { 
            return Win32Native.LocalFree(handle) == IntPtr.Zero;
        } 
    }

    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeLsaLogonProcessHandle : SafeHandleZeroOrMinusOneIsInvalid { 
        private SafeLsaLogonProcessHandle() : base (true) {}
 
        // 0 is an Invalid Handle 
        internal SafeLsaLogonProcessHandle(IntPtr handle) : base (true) {
            SetHandle(handle); 
        }

        internal static SafeLsaLogonProcessHandle InvalidHandle {
            get { return new SafeLsaLogonProcessHandle(IntPtr.Zero); } 
        }
 
        [System.Security.SecurityCritical] 
        override protected bool ReleaseHandle()
        { 
            // LsaDeregisterLogonProcess returns an NTSTATUS
            return Win32Native.LsaDeregisterLogonProcess(handle) >= 0;
        }
    } 

    [System.Security.SecurityCritical]  // auto-generated 
    internal sealed class SafeLsaMemoryHandle : SafeBuffer { 
        private SafeLsaMemoryHandle() : base(true) {}
 
        // 0 is an Invalid Handle
        internal SafeLsaMemoryHandle(IntPtr handle) : base (true) {
            SetHandle(handle);
        } 

        internal static SafeLsaMemoryHandle InvalidHandle { 
            get { return new SafeLsaMemoryHandle( IntPtr.Zero ); } 
        }
 
        [System.Security.SecurityCritical]
        override protected bool ReleaseHandle()
        {
            return Win32Native.LsaFreeMemory(handle) == 0; 
        }
    } 
 
    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeLsaPolicyHandle : SafeHandleZeroOrMinusOneIsInvalid { 
        private SafeLsaPolicyHandle() : base(true) {}

        // 0 is an Invalid Handle
        internal SafeLsaPolicyHandle(IntPtr handle) : base (true) { 
            SetHandle(handle);
        } 
 
        internal static SafeLsaPolicyHandle InvalidHandle {
            get { return new SafeLsaPolicyHandle( IntPtr.Zero ); } 
        }

        [System.Security.SecurityCritical]
        override protected bool ReleaseHandle() 
        {
            return Win32Native.LsaClose(handle) == 0; 
        } 
    }
 
    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeLsaReturnBufferHandle : SafeBuffer {
        private SafeLsaReturnBufferHandle() : base (true) {}
 
        // 0 is an Invalid Handle
        internal SafeLsaReturnBufferHandle(IntPtr handle) : base (true) { 
            SetHandle(handle); 
        }
 
        internal static SafeLsaReturnBufferHandle InvalidHandle {
            get { return new SafeLsaReturnBufferHandle(IntPtr.Zero); }
        }
 
        [System.Security.SecurityCritical]
        override protected bool ReleaseHandle() 
        { 
            // LsaFreeReturnBuffer returns an NTSTATUS
            return Win32Native.LsaFreeReturnBuffer(handle) >= 0; 
        }
    }

    [System.Security.SecurityCritical]  // auto-generated 
    internal sealed class SafeProcessHandle : SafeHandleZeroOrMinusOneIsInvalid {
        private SafeProcessHandle() : base (true) {} 
 
        // 0 is an Invalid Handle
        internal SafeProcessHandle(IntPtr handle) : base (true) { 
            SetHandle(handle);
        }

        internal static SafeProcessHandle InvalidHandle { 
            get { return new SafeProcessHandle(IntPtr.Zero); }
        } 
 
        [System.Security.SecurityCritical]
        [ResourceExposure(ResourceScope.None)] 
        [ResourceConsumption(ResourceScope.Machine, ResourceScope.Machine)]
        override protected bool ReleaseHandle()
        {
            return Win32Native.CloseHandle(handle); 
        }
    } 
 
    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeThreadHandle : SafeHandleZeroOrMinusOneIsInvalid { 
        private SafeThreadHandle() : base (true) {}

        // 0 is an Invalid Handle
        internal SafeThreadHandle(IntPtr handle) : base (true) { 
            SetHandle(handle);
        } 
 
        [System.Security.SecurityCritical]
        [ResourceExposure(ResourceScope.None)] 
        [ResourceConsumption(ResourceScope.Machine, ResourceScope.Machine)]
        override protected bool ReleaseHandle()
        {
            return Win32Native.CloseHandle(handle); 
        }
    } 
 
    [System.Security.SecurityCritical]  // auto-generated
    internal sealed class SafeTokenHandle : SafeHandleZeroOrMinusOneIsInvalid { 
        private SafeTokenHandle() : base (true) {}

        // 0 is an Invalid Handle
        internal SafeTokenHandle(IntPtr handle) : base (true) { 
            SetHandle(handle);
        } 
 
        internal static SafeTokenHandle InvalidHandle {
            get { return new SafeTokenHandle(IntPtr.Zero); } 
        }

        [System.Security.SecurityCritical]
        [ResourceExposure(ResourceScope.None)] 
        [ResourceConsumption(ResourceScope.Machine, ResourceScope.Machine)]
        override protected bool ReleaseHandle() 
        { 
            return Win32Native.CloseHandle(handle);
        } 
    }

#endif // !FEATURE_PAL
} 

// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// Copyright (c) Microsoft Corporation. All rights reserved.

                        

Link Menu

Network programming in C#, Network Programming in VB.NET, Network Programming in .NET
This book is available now!
Buy at Amazon US or
Buy at Amazon UK