Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / clr / src / BCL / System / Security / AccessControl / CryptoKeySecurity.cs / 1 / CryptoKeySecurity.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // // CryptoKeySecurity.cs // using System.Security.Cryptography; using System.Security.Permissions; using System.Security.Principal; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; namespace System.Security.AccessControl { [Flags] public enum CryptoKeyRights { ReadData = 0x00000001, WriteData = 0x00000002, ReadExtendedAttributes = 0x00000008, WriteExtendedAttributes = 0x00000010, ReadAttributes = 0x00000080, WriteAttributes = 0x00000100, Delete = 0x00010000, ReadPermissions = 0x00020000, ChangePermissions = 0x00040000, TakeOwnership = 0x00080000, Synchronize = 0x00100000, FullControl = 0x001F019B, GenericAll = 0x10000000, GenericExecute = 0x20000000, GenericWrite = 0x40000000, GenericRead = unchecked((int) 0x80000000) } public sealed class CryptoKeyAccessRule : AccessRule { public CryptoKeyAccessRule (IdentityReference identity, CryptoKeyRights cryptoKeyRights, AccessControlType type) : this (identity, AccessMaskFromRights(cryptoKeyRights, type), false, InheritanceFlags.None, PropagationFlags.None, type) { } public CryptoKeyAccessRule (string identity, CryptoKeyRights cryptoKeyRights, AccessControlType type) : this (new NTAccount(identity), AccessMaskFromRights(cryptoKeyRights, type), false, InheritanceFlags.None, PropagationFlags.None, type) { } private CryptoKeyAccessRule (IdentityReference identity, int accessMask, bool isInherited, InheritanceFlags inheritanceFlags, PropagationFlags propagationFlags, AccessControlType type) : base (identity, accessMask, isInherited, inheritanceFlags, propagationFlags, type) { } public CryptoKeyRights CryptoKeyRights { get { return RightsFromAccessMask(base.AccessMask); } } // Acl's on files have a Synchronize bit, and CreateFile always // asks for it. So for allows, let's always include this bit, // and for denies, let's never include this bit unless we're denying // full control. This is the right thing for users, even if it does // make the model look asymmetrical from a purist point of view. // Also, crypto key containers are just files in the end, so // this tweak to the access rights for files makes sense here. private static int AccessMaskFromRights (CryptoKeyRights cryptoKeyRights, AccessControlType controlType) { if (controlType == AccessControlType.Allow) { cryptoKeyRights |= CryptoKeyRights.Synchronize; } else if (controlType == AccessControlType.Deny) { if (cryptoKeyRights != CryptoKeyRights.FullControl) cryptoKeyRights &= ~CryptoKeyRights.Synchronize; } else { throw new ArgumentException(Environment.GetResourceString("Argument_InvalidEnumValue", controlType, "controlType"), "controlType"); } return (int) cryptoKeyRights; } internal static CryptoKeyRights RightsFromAccessMask(int accessMask) { return (CryptoKeyRights) accessMask; } } public sealed class CryptoKeyAuditRule : AuditRule { public CryptoKeyAuditRule (IdentityReference identity, CryptoKeyRights cryptoKeyRights, AuditFlags flags) : this (identity, AccessMaskFromRights(cryptoKeyRights), false, InheritanceFlags.None, PropagationFlags.None, flags) { } public CryptoKeyAuditRule (string identity, CryptoKeyRights cryptoKeyRights, AuditFlags flags) : this (new NTAccount(identity), AccessMaskFromRights(cryptoKeyRights), false, InheritanceFlags.None, PropagationFlags.None, flags) { } private CryptoKeyAuditRule (IdentityReference identity, int accessMask, bool isInherited, InheritanceFlags inheritanceFlags, PropagationFlags propagationFlags, AuditFlags flags) : base (identity, accessMask, isInherited, inheritanceFlags, propagationFlags, flags) { } public CryptoKeyRights CryptoKeyRights { get { return RightsFromAccessMask(base.AccessMask); } } private static int AccessMaskFromRights (CryptoKeyRights cryptoKeyRights) { return (int) cryptoKeyRights; } internal static CryptoKeyRights RightsFromAccessMask(int accessMask) { return (CryptoKeyRights) accessMask; } } public sealed class CryptoKeySecurity : NativeObjectSecurity { private const ResourceType s_ResourceType = ResourceType.FileObject; public CryptoKeySecurity () : base(false, s_ResourceType) {} public CryptoKeySecurity (CommonSecurityDescriptor securityDescriptor) : base(s_ResourceType, securityDescriptor) {} public sealed override AccessRule AccessRuleFactory (IdentityReference identityReference, int accessMask, bool isInherited, InheritanceFlags inheritanceFlags, PropagationFlags propagationFlags, AccessControlType type) { return new CryptoKeyAccessRule( identityReference, CryptoKeyAccessRule.RightsFromAccessMask(accessMask), type); } public sealed override AuditRule AuditRuleFactory (IdentityReference identityReference, int accessMask, bool isInherited, InheritanceFlags inheritanceFlags, PropagationFlags propagationFlags, AuditFlags flags) { return new CryptoKeyAuditRule( identityReference, CryptoKeyAuditRule.RightsFromAccessMask(accessMask), flags); } public void AddAccessRule (CryptoKeyAccessRule rule) { base.AddAccessRule(rule); } public void SetAccessRule (CryptoKeyAccessRule rule) { base.SetAccessRule(rule); } public void ResetAccessRule (CryptoKeyAccessRule rule) { base.ResetAccessRule(rule); } public bool RemoveAccessRule (CryptoKeyAccessRule rule) { return base.RemoveAccessRule(rule); } public void RemoveAccessRuleAll (CryptoKeyAccessRule rule) { base.RemoveAccessRuleAll(rule); } public void RemoveAccessRuleSpecific (CryptoKeyAccessRule rule) { base.RemoveAccessRuleSpecific(rule); } public void AddAuditRule (CryptoKeyAuditRule rule) { base.AddAuditRule(rule); } public void SetAuditRule (CryptoKeyAuditRule rule) { base.SetAuditRule(rule); } public bool RemoveAuditRule (CryptoKeyAuditRule rule) { return base.RemoveAuditRule(rule); } public void RemoveAuditRuleAll (CryptoKeyAuditRule rule) { base.RemoveAuditRuleAll(rule); } public void RemoveAuditRuleSpecific (CryptoKeyAuditRule rule) { base.RemoveAuditRuleSpecific(rule); } #region some overrides public override Type AccessRightType { get { return typeof(System.Security.AccessControl.CryptoKeyRights); } } public override Type AccessRuleType { get { return typeof(System.Security.AccessControl.CryptoKeyAccessRule); } } public override Type AuditRuleType { get { return typeof(System.Security.AccessControl.CryptoKeyAuditRule); } } #endregion internal AccessControlSections ChangedAccessControlSections { get { AccessControlSections changedSections = AccessControlSections.None; bool readLockAcquired = false; RuntimeHelpers.PrepareConstrainedRegions(); try { RuntimeHelpers.PrepareConstrainedRegions(); try { } finally { ReadLock(); readLockAcquired = true; } if (AccessRulesModified) changedSections |= AccessControlSections.Access; if (AuditRulesModified) changedSections |= AccessControlSections.Audit; if (GroupModified) changedSections |= AccessControlSections.Group; if (OwnerModified) changedSections |= AccessControlSections.Owner; } finally { if (readLockAcquired) { ReadUnlock(); } } return changedSections; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // // CryptoKeySecurity.cs // using System.Security.Cryptography; using System.Security.Permissions; using System.Security.Principal; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; namespace System.Security.AccessControl { [Flags] public enum CryptoKeyRights { ReadData = 0x00000001, WriteData = 0x00000002, ReadExtendedAttributes = 0x00000008, WriteExtendedAttributes = 0x00000010, ReadAttributes = 0x00000080, WriteAttributes = 0x00000100, Delete = 0x00010000, ReadPermissions = 0x00020000, ChangePermissions = 0x00040000, TakeOwnership = 0x00080000, Synchronize = 0x00100000, FullControl = 0x001F019B, GenericAll = 0x10000000, GenericExecute = 0x20000000, GenericWrite = 0x40000000, GenericRead = unchecked((int) 0x80000000) } public sealed class CryptoKeyAccessRule : AccessRule { public CryptoKeyAccessRule (IdentityReference identity, CryptoKeyRights cryptoKeyRights, AccessControlType type) : this (identity, AccessMaskFromRights(cryptoKeyRights, type), false, InheritanceFlags.None, PropagationFlags.None, type) { } public CryptoKeyAccessRule (string identity, CryptoKeyRights cryptoKeyRights, AccessControlType type) : this (new NTAccount(identity), AccessMaskFromRights(cryptoKeyRights, type), false, InheritanceFlags.None, PropagationFlags.None, type) { } private CryptoKeyAccessRule (IdentityReference identity, int accessMask, bool isInherited, InheritanceFlags inheritanceFlags, PropagationFlags propagationFlags, AccessControlType type) : base (identity, accessMask, isInherited, inheritanceFlags, propagationFlags, type) { } public CryptoKeyRights CryptoKeyRights { get { return RightsFromAccessMask(base.AccessMask); } } // Acl's on files have a Synchronize bit, and CreateFile always // asks for it. So for allows, let's always include this bit, // and for denies, let's never include this bit unless we're denying // full control. This is the right thing for users, even if it does // make the model look asymmetrical from a purist point of view. // Also, crypto key containers are just files in the end, so // this tweak to the access rights for files makes sense here. private static int AccessMaskFromRights (CryptoKeyRights cryptoKeyRights, AccessControlType controlType) { if (controlType == AccessControlType.Allow) { cryptoKeyRights |= CryptoKeyRights.Synchronize; } else if (controlType == AccessControlType.Deny) { if (cryptoKeyRights != CryptoKeyRights.FullControl) cryptoKeyRights &= ~CryptoKeyRights.Synchronize; } else { throw new ArgumentException(Environment.GetResourceString("Argument_InvalidEnumValue", controlType, "controlType"), "controlType"); } return (int) cryptoKeyRights; } internal static CryptoKeyRights RightsFromAccessMask(int accessMask) { return (CryptoKeyRights) accessMask; } } public sealed class CryptoKeyAuditRule : AuditRule { public CryptoKeyAuditRule (IdentityReference identity, CryptoKeyRights cryptoKeyRights, AuditFlags flags) : this (identity, AccessMaskFromRights(cryptoKeyRights), false, InheritanceFlags.None, PropagationFlags.None, flags) { } public CryptoKeyAuditRule (string identity, CryptoKeyRights cryptoKeyRights, AuditFlags flags) : this (new NTAccount(identity), AccessMaskFromRights(cryptoKeyRights), false, InheritanceFlags.None, PropagationFlags.None, flags) { } private CryptoKeyAuditRule (IdentityReference identity, int accessMask, bool isInherited, InheritanceFlags inheritanceFlags, PropagationFlags propagationFlags, AuditFlags flags) : base (identity, accessMask, isInherited, inheritanceFlags, propagationFlags, flags) { } public CryptoKeyRights CryptoKeyRights { get { return RightsFromAccessMask(base.AccessMask); } } private static int AccessMaskFromRights (CryptoKeyRights cryptoKeyRights) { return (int) cryptoKeyRights; } internal static CryptoKeyRights RightsFromAccessMask(int accessMask) { return (CryptoKeyRights) accessMask; } } public sealed class CryptoKeySecurity : NativeObjectSecurity { private const ResourceType s_ResourceType = ResourceType.FileObject; public CryptoKeySecurity () : base(false, s_ResourceType) {} public CryptoKeySecurity (CommonSecurityDescriptor securityDescriptor) : base(s_ResourceType, securityDescriptor) {} public sealed override AccessRule AccessRuleFactory (IdentityReference identityReference, int accessMask, bool isInherited, InheritanceFlags inheritanceFlags, PropagationFlags propagationFlags, AccessControlType type) { return new CryptoKeyAccessRule( identityReference, CryptoKeyAccessRule.RightsFromAccessMask(accessMask), type); } public sealed override AuditRule AuditRuleFactory (IdentityReference identityReference, int accessMask, bool isInherited, InheritanceFlags inheritanceFlags, PropagationFlags propagationFlags, AuditFlags flags) { return new CryptoKeyAuditRule( identityReference, CryptoKeyAuditRule.RightsFromAccessMask(accessMask), flags); } public void AddAccessRule (CryptoKeyAccessRule rule) { base.AddAccessRule(rule); } public void SetAccessRule (CryptoKeyAccessRule rule) { base.SetAccessRule(rule); } public void ResetAccessRule (CryptoKeyAccessRule rule) { base.ResetAccessRule(rule); } public bool RemoveAccessRule (CryptoKeyAccessRule rule) { return base.RemoveAccessRule(rule); } public void RemoveAccessRuleAll (CryptoKeyAccessRule rule) { base.RemoveAccessRuleAll(rule); } public void RemoveAccessRuleSpecific (CryptoKeyAccessRule rule) { base.RemoveAccessRuleSpecific(rule); } public void AddAuditRule (CryptoKeyAuditRule rule) { base.AddAuditRule(rule); } public void SetAuditRule (CryptoKeyAuditRule rule) { base.SetAuditRule(rule); } public bool RemoveAuditRule (CryptoKeyAuditRule rule) { return base.RemoveAuditRule(rule); } public void RemoveAuditRuleAll (CryptoKeyAuditRule rule) { base.RemoveAuditRuleAll(rule); } public void RemoveAuditRuleSpecific (CryptoKeyAuditRule rule) { base.RemoveAuditRuleSpecific(rule); } #region some overrides public override Type AccessRightType { get { return typeof(System.Security.AccessControl.CryptoKeyRights); } } public override Type AccessRuleType { get { return typeof(System.Security.AccessControl.CryptoKeyAccessRule); } } public override Type AuditRuleType { get { return typeof(System.Security.AccessControl.CryptoKeyAuditRule); } } #endregion internal AccessControlSections ChangedAccessControlSections { get { AccessControlSections changedSections = AccessControlSections.None; bool readLockAcquired = false; RuntimeHelpers.PrepareConstrainedRegions(); try { RuntimeHelpers.PrepareConstrainedRegions(); try { } finally { ReadLock(); readLockAcquired = true; } if (AccessRulesModified) changedSections |= AccessControlSections.Access; if (AuditRulesModified) changedSections |= AccessControlSections.Audit; if (GroupModified) changedSections |= AccessControlSections.Group; if (OwnerModified) changedSections |= AccessControlSections.Owner; } finally { if (readLockAcquired) { ReadUnlock(); } } return changedSections; } } } } // 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
- SimplePropertyEntry.cs
- DataGridViewMethods.cs
- XmlKeywords.cs
- Transform.cs
- HtmlTableRow.cs
- RootBrowserWindow.cs
- InvokeHandlers.cs
- BaseInfoTable.cs
- DropShadowBitmapEffect.cs
- ListViewGroupConverter.cs
- DataList.cs
- CompatibleComparer.cs
- LinkClickEvent.cs
- LinqDataSource.cs
- SelectionEditor.cs
- FacetChecker.cs
- StandardToolWindows.cs
- DataGridToolTip.cs
- TripleDES.cs
- BinHexEncoding.cs
- Application.cs
- EntityDataSourceReferenceGroup.cs
- RtfToXamlLexer.cs
- SafeNativeMethods.cs
- ClusterRegistryConfigurationProvider.cs
- Normalization.cs
- HttpCapabilitiesSectionHandler.cs
- ArraySegment.cs
- WindowsIPAddress.cs
- TemplateXamlParser.cs
- OdbcTransaction.cs
- WorkerProcess.cs
- UserMapPath.cs
- ComponentEditorPage.cs
- DriveNotFoundException.cs
- ErrorEventArgs.cs
- PersonalizationStateInfo.cs
- DesignSurface.cs
- DataGridViewLinkColumn.cs
- DBProviderConfigurationHandler.cs
- HttpCachePolicyElement.cs
- SocketInformation.cs
- EventTrigger.cs
- MailAddress.cs
- ListItemCollection.cs
- MultiBinding.cs
- DrawingCollection.cs
- UnmanagedMemoryStreamWrapper.cs
- ContractMapping.cs
- WebPartDisplayModeCollection.cs
- HitTestResult.cs
- KeysConverter.cs
- Point.cs
- WSSecurityOneDotZeroReceiveSecurityHeader.cs
- BoundColumn.cs
- EmptyQuery.cs
- SslStream.cs
- InfoCardSymmetricCrypto.cs
- login.cs
- Task.cs
- AttributeConverter.cs
- RegexWorker.cs
- PeerName.cs
- PropertyGridCommands.cs
- FileDialogCustomPlace.cs
- TrustManager.cs
- StreamSecurityUpgradeInitiatorAsyncResult.cs
- RouteUrlExpressionBuilder.cs
- EventHandlers.cs
- NonSerializedAttribute.cs
- FileLoadException.cs
- SafeMILHandleMemoryPressure.cs
- RegexTypeEditor.cs
- BindingMemberInfo.cs
- DataObjectCopyingEventArgs.cs
- FamilyTypeface.cs
- Parallel.cs
- SuppressMergeCheckAttribute.cs
- UserControl.cs
- RangeBase.cs
- WindowsSecurityTokenAuthenticator.cs
- ExclusiveHandle.cs
- UnmanagedMemoryStreamWrapper.cs
- SqlCacheDependencySection.cs
- PageEventArgs.cs
- NotifyParentPropertyAttribute.cs
- AccessDataSourceView.cs
- SqlUserDefinedAggregateAttribute.cs
- UIElementAutomationPeer.cs
- FileAuthorizationModule.cs
- XmlSchemaComplexContent.cs
- CheckBoxField.cs
- ObjectDataSourceWizardForm.cs
- ConfigurationSectionGroupCollection.cs
- StateDesigner.cs
- ProjectionCamera.cs
- BindableTemplateBuilder.cs
- Identifier.cs
- log.cs
- PenThreadWorker.cs