You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			268 lines
		
	
	
		
			9.0 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			268 lines
		
	
	
		
			9.0 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| // ==++==
 | |
| // 
 | |
| //   Copyright (c) Microsoft Corporation.  All rights reserved.
 | |
| // 
 | |
| // ==--==
 | |
| /*============================================================
 | |
| **
 | |
| ** Class:  SemaphoreSecurity
 | |
| **
 | |
| ** Purpose: Managed ACL wrapper for Win32 semaphores.
 | |
| **
 | |
| ** Date:  November 26, 2003
 | |
| **
 | |
| ===========================================================*/
 | |
| 
 | |
| using System;
 | |
| using System.Collections;
 | |
| using System.Security.Permissions;
 | |
| using System.Security.Principal;
 | |
| using Microsoft.Win32;
 | |
| using Microsoft.Win32.SafeHandles;
 | |
| using System.Runtime.InteropServices;
 | |
| using System.IO;
 | |
| using System.Threading;
 | |
| 
 | |
| namespace System.Security.AccessControl
 | |
| {
 | |
|     // Derive this list of values from winnt.h and MSDN docs:
 | |
|     // http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dllproc/base/synchronization_object_security_and_access_rights.asp
 | |
| 
 | |
|     // Win32's interesting values are SEMAPHORE_MODIFY_STATE (0x2) and
 | |
|     // SEMAPHORE_ALL_ACCESS (0x1F0003).  I don't know what 0x1 is.
 | |
|     [Flags, ComVisible(false)]
 | |
|     public enum SemaphoreRights
 | |
|     {
 | |
|         Modify               = 0x000002,
 | |
|         Delete               = 0x010000,
 | |
|         ReadPermissions      = 0x020000,
 | |
|         ChangePermissions    = 0x040000,
 | |
|         TakeOwnership        = 0x080000,
 | |
|         Synchronize          = 0x100000,  // SYNCHRONIZE
 | |
|         FullControl          = 0x1F0003
 | |
|     }
 | |
| 
 | |
|     [ComVisible(false)]
 | |
|     public sealed class SemaphoreAccessRule : AccessRule
 | |
|     {
 | |
|         // Constructor for creating access rules for registry objects
 | |
| 
 | |
|         public SemaphoreAccessRule(IdentityReference identity, SemaphoreRights eventRights, AccessControlType type) 
 | |
|             : this(identity, (int) eventRights, false, InheritanceFlags.None, PropagationFlags.None, type)
 | |
|         {
 | |
|         }
 | |
| 
 | |
|         public SemaphoreAccessRule(String identity, SemaphoreRights eventRights, AccessControlType type) 
 | |
|             : this(new NTAccount(identity), (int) eventRights, false, InheritanceFlags.None, PropagationFlags.None, type)
 | |
|         {
 | |
|         }
 | |
| 
 | |
|         //
 | |
|         // Internal constructor to be called by public constructors
 | |
|         // and the access rule factory methods of {File|Folder}Security
 | |
|         //
 | |
|         internal SemaphoreAccessRule(
 | |
|             IdentityReference identity,
 | |
|             int accessMask,
 | |
|             bool isInherited,
 | |
|             InheritanceFlags inheritanceFlags,
 | |
|             PropagationFlags propagationFlags,
 | |
|             AccessControlType type )
 | |
|             : base(
 | |
|                 identity,
 | |
|                 accessMask,
 | |
|                 isInherited,
 | |
|                 inheritanceFlags,
 | |
|                 propagationFlags,
 | |
|                 type )
 | |
|         {
 | |
|         }
 | |
| 
 | |
|         public SemaphoreRights SemaphoreRights { 
 | |
|             get { return (SemaphoreRights) base.AccessMask; }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     [ComVisible(false)]
 | |
|     public sealed class SemaphoreAuditRule : AuditRule
 | |
|     {
 | |
|         public SemaphoreAuditRule(IdentityReference identity, SemaphoreRights eventRights, AuditFlags flags)
 | |
|             : this(identity, (int) eventRights, false, InheritanceFlags.None, PropagationFlags.None, flags)
 | |
|         {
 | |
|         }
 | |
| 
 | |
|         /*  // Not in the spec
 | |
|         public SemaphoreAuditRule(string identity, SemaphoreRights eventRights, AuditFlags flags)
 | |
|             : this(new NTAccount(identity), (int) eventRights, false, InheritanceFlags.None, PropagationFlags.None, flags)
 | |
|         {
 | |
|         }
 | |
|         */
 | |
| 
 | |
|         internal SemaphoreAuditRule(IdentityReference identity, int accessMask, bool isInherited, InheritanceFlags inheritanceFlags, PropagationFlags propagationFlags, AuditFlags flags)
 | |
|             : base(identity, accessMask, isInherited, inheritanceFlags, propagationFlags, flags)
 | |
|         {
 | |
|         }
 | |
|         
 | |
|         public SemaphoreRights SemaphoreRights { 
 | |
|             get { return (SemaphoreRights) base.AccessMask; }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     [ComVisible(false)]
 | |
|     public sealed class SemaphoreSecurity : NativeObjectSecurity
 | |
|     {
 | |
|         public SemaphoreSecurity()
 | |
|             : base(true, ResourceType.KernelObject)
 | |
|         {
 | |
|         }
 | |
| 
 | |
|         public SemaphoreSecurity(String name, AccessControlSections includeSections)
 | |
|             : base(true, ResourceType.KernelObject, name, includeSections, _HandleErrorCode, null)
 | |
|         {
 | |
|             // Let the underlying ACL API's demand unmanaged code permission.
 | |
|         }
 | |
| 
 | |
|         internal SemaphoreSecurity(SafeWaitHandle handle, AccessControlSections includeSections)
 | |
|             : base(true, ResourceType.KernelObject, handle, includeSections, _HandleErrorCode, null)
 | |
|         {
 | |
|             // Let the underlying ACL API's demand unmanaged code permission.
 | |
|         }
 | |
| 
 | |
|         private static Exception _HandleErrorCode(int errorCode, string name, SafeHandle handle, object context)
 | |
|         {
 | |
|             System.Exception exception = null;
 | |
|             
 | |
|             switch (errorCode) {
 | |
|             case NativeMethods.ERROR_INVALID_NAME:
 | |
|             case NativeMethods.ERROR_INVALID_HANDLE:
 | |
|             case NativeMethods.ERROR_FILE_NOT_FOUND:
 | |
|                 if ((name != null) && (name.Length != 0))
 | |
|                     exception = new WaitHandleCannotBeOpenedException(SR.GetString(SR.WaitHandleCannotBeOpenedException_InvalidHandle, name));
 | |
|                 else
 | |
|                     exception = new WaitHandleCannotBeOpenedException();
 | |
|                 break;
 | |
| 
 | |
|             default:
 | |
|                 break;
 | |
|             }
 | |
| 
 | |
|             return exception;
 | |
|         }
 | |
| 
 | |
|         public override AccessRule AccessRuleFactory(IdentityReference identityReference, int accessMask, bool isInherited, InheritanceFlags inheritanceFlags, PropagationFlags propagationFlags, AccessControlType type)
 | |
|         {
 | |
|             return new SemaphoreAccessRule(identityReference, accessMask, isInherited, inheritanceFlags, propagationFlags, type);
 | |
|         }
 | |
| 
 | |
|         public override AuditRule AuditRuleFactory(IdentityReference identityReference, int accessMask, bool isInherited, InheritanceFlags inheritanceFlags, PropagationFlags propagationFlags, AuditFlags flags)
 | |
|         {
 | |
|             return new SemaphoreAuditRule(identityReference, accessMask, isInherited, inheritanceFlags, propagationFlags, flags);
 | |
|         }
 | |
| 
 | |
|         internal AccessControlSections GetAccessControlSectionsFromChanges()
 | |
|         {
 | |
|             AccessControlSections persistRules = AccessControlSections.None;
 | |
|             if (AccessRulesModified)
 | |
|                 persistRules = AccessControlSections.Access;
 | |
|             if (AuditRulesModified)
 | |
|                 persistRules |= AccessControlSections.Audit;
 | |
|             if (OwnerModified)
 | |
|                 persistRules |= AccessControlSections.Owner;
 | |
|             if (GroupModified)
 | |
|                 persistRules |= AccessControlSections.Group;
 | |
|             return persistRules;
 | |
|         }
 | |
| 
 | |
|         internal void Persist(SafeWaitHandle handle)
 | |
|         {
 | |
|             // Let the underlying ACL API's demand unmanaged code.
 | |
| 
 | |
|             WriteLock();
 | |
| 
 | |
|             try
 | |
|             {
 | |
|                 AccessControlSections persistSections = GetAccessControlSectionsFromChanges();
 | |
|                 if (persistSections == AccessControlSections.None)
 | |
|                     return;  // Don't need to persist anything.
 | |
| 
 | |
|                 base.Persist(handle, persistSections);
 | |
|                 OwnerModified = GroupModified = AuditRulesModified = AccessRulesModified = false;
 | |
|             }
 | |
|             finally
 | |
|             {
 | |
|                 WriteUnlock();
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         public void AddAccessRule(SemaphoreAccessRule rule)
 | |
|         {
 | |
|             base.AddAccessRule(rule);
 | |
|         }
 | |
| 
 | |
|         public void SetAccessRule(SemaphoreAccessRule rule)
 | |
|         {
 | |
|             base.SetAccessRule(rule);
 | |
|         }
 | |
| 
 | |
|         public void ResetAccessRule(SemaphoreAccessRule rule)
 | |
|         {
 | |
|             base.ResetAccessRule(rule);
 | |
|         }
 | |
| 
 | |
|         public bool RemoveAccessRule(SemaphoreAccessRule rule)
 | |
|         {
 | |
|             return base.RemoveAccessRule(rule);
 | |
|         }
 | |
| 
 | |
|         public void RemoveAccessRuleAll(SemaphoreAccessRule rule)
 | |
|         {
 | |
|             base.RemoveAccessRuleAll(rule);
 | |
|         }
 | |
| 
 | |
|         public void RemoveAccessRuleSpecific(SemaphoreAccessRule rule)
 | |
|         {
 | |
|             base.RemoveAccessRuleSpecific(rule);
 | |
|         }
 | |
|                 
 | |
|         public void AddAuditRule(SemaphoreAuditRule rule)
 | |
|         {
 | |
|             base.AddAuditRule(rule);
 | |
|         }
 | |
| 
 | |
|         public void SetAuditRule(SemaphoreAuditRule rule)
 | |
|         {
 | |
|             base.SetAuditRule(rule);
 | |
|         }
 | |
| 
 | |
|         public bool RemoveAuditRule(SemaphoreAuditRule rule)
 | |
|         {
 | |
|             return base.RemoveAuditRule(rule);
 | |
|         }
 | |
| 
 | |
|         public void RemoveAuditRuleAll(SemaphoreAuditRule rule)
 | |
|         {
 | |
|             base.RemoveAuditRuleAll(rule);
 | |
|         }
 | |
| 
 | |
|         public void RemoveAuditRuleSpecific(SemaphoreAuditRule rule)
 | |
|         {
 | |
|             base.RemoveAuditRuleSpecific(rule);
 | |
|         }
 | |
| 
 | |
|         public override Type AccessRightType
 | |
|         {
 | |
|             get { return typeof(SemaphoreRights); }
 | |
|         }
 | |
|         
 | |
|         public override Type AccessRuleType
 | |
|         {
 | |
|             get { return typeof(SemaphoreAccessRule); }
 | |
|         }
 | |
|         
 | |
|         public override Type AuditRuleType
 | |
|         {
 | |
|             get { return typeof(SemaphoreAuditRule); }
 | |
|         }
 | |
|     }
 | |
| }
 |