Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / clr / src / BCL / System / Security / Policy / Zone.cs / 1305376 / Zone.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== //[....] // // // Zone.cs // // Zone is an IIdentity representing Internet/Intranet/MyComputer etc. // namespace System.Security.Policy { using System.Security.Util; using ZoneIdentityPermission = System.Security.Permissions.ZoneIdentityPermission; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Runtime.Versioning; using System.Runtime.Serialization; using System.Diagnostics.Contracts; [Serializable] [System.Runtime.InteropServices.ComVisible(true)] public sealed class Zone : EvidenceBase, IIdentityPermissionFactory { #if FEATURE_CAS_POLICY [OptionalField(VersionAdded = 2)] private String m_url; #endif // FEATURE_CAS_POLICY private SecurityZone m_zone; private static readonly String[] s_names = {"MyComputer", "Intranet", "Trusted", "Internet", "Untrusted", "NoZone"}; public Zone(SecurityZone zone) { if (zone < SecurityZone.NoZone || zone > SecurityZone.Untrusted) throw new ArgumentException( Environment.GetResourceString( "Argument_IllegalZone" ) ); Contract.EndContractBlock(); m_zone = zone; } private Zone(Zone zone) { Contract.Assert(zone != null); #if FEATURE_CAS_POLICY m_url = zone.m_url; #endif // FEATURE_CAS_POLICY m_zone = zone.m_zone; } #if FEATURE_CAS_POLICY private Zone(String url) { m_url = url; m_zone = SecurityZone.NoZone; } public static Zone CreateFromUrl( String url ) { if (url == null) throw new ArgumentNullException( "url" ); Contract.EndContractBlock(); return new Zone( url ); } [System.Security.SecurityCritical] // auto-generated [ResourceExposure(ResourceScope.None)] [DllImport(JitHelpers.QCall, CharSet = CharSet.Unicode)] [SuppressUnmanagedCodeSecurity] private extern static SecurityZone _CreateFromUrl( String url ); #endif // FEATURE_CAS_POLICY public IPermission CreateIdentityPermission( Evidence evidence ) { return new ZoneIdentityPermission( SecurityZone ); } public SecurityZone SecurityZone { [System.Security.SecuritySafeCritical] // auto-generated get { #if FEATURE_CAS_POLICY if (m_url != null) m_zone = _CreateFromUrl( m_url ); #endif // FEATURE_CAS_POLICY return m_zone; } } public override bool Equals(Object o) { Zone other = o as Zone; if (other == null) { return false; } return SecurityZone == other.SecurityZone; } public override int GetHashCode() { return (int)SecurityZone; } public override EvidenceBase Clone() { return new Zone(this); } public Object Copy() { return Clone(); } #if FEATURE_CAS_POLICY internal SecurityElement ToXml() { SecurityElement elem = new SecurityElement( "System.Security.Policy.Zone" ); // If you hit this assert then most likely you are trying to change the name of this class. // This is ok as long as you change the hard coded string above and change the assert below. Contract.Assert( this.GetType().FullName.Equals( "System.Security.Policy.Zone" ), "Class name changed!" ); elem.AddAttribute( "version", "1" ); if (SecurityZone != SecurityZone.NoZone) elem.AddChild( new SecurityElement( "Zone", s_names[(int)SecurityZone] ) ); else elem.AddChild( new SecurityElement( "Zone", s_names[s_names.Length-1] ) ); return elem; } #endif // FEATURE_CAS_POLICY #if FEATURE_CAS_POLICY public override String ToString() { return ToXml().ToString(); } #endif // FEATURE_CAS_POLICY // INormalizeForIsolatedStorage is not implemented for startup perf // equivalent to INormalizeForIsolatedStorage.Normalize() internal Object Normalize() { return s_names[(int)SecurityZone]; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== //[....] // // // Zone.cs // // Zone is an IIdentity representing Internet/Intranet/MyComputer etc. // namespace System.Security.Policy { using System.Security.Util; using ZoneIdentityPermission = System.Security.Permissions.ZoneIdentityPermission; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Runtime.Versioning; using System.Runtime.Serialization; using System.Diagnostics.Contracts; [Serializable] [System.Runtime.InteropServices.ComVisible(true)] public sealed class Zone : EvidenceBase, IIdentityPermissionFactory { #if FEATURE_CAS_POLICY [OptionalField(VersionAdded = 2)] private String m_url; #endif // FEATURE_CAS_POLICY private SecurityZone m_zone; private static readonly String[] s_names = {"MyComputer", "Intranet", "Trusted", "Internet", "Untrusted", "NoZone"}; public Zone(SecurityZone zone) { if (zone < SecurityZone.NoZone || zone > SecurityZone.Untrusted) throw new ArgumentException( Environment.GetResourceString( "Argument_IllegalZone" ) ); Contract.EndContractBlock(); m_zone = zone; } private Zone(Zone zone) { Contract.Assert(zone != null); #if FEATURE_CAS_POLICY m_url = zone.m_url; #endif // FEATURE_CAS_POLICY m_zone = zone.m_zone; } #if FEATURE_CAS_POLICY private Zone(String url) { m_url = url; m_zone = SecurityZone.NoZone; } public static Zone CreateFromUrl( String url ) { if (url == null) throw new ArgumentNullException( "url" ); Contract.EndContractBlock(); return new Zone( url ); } [System.Security.SecurityCritical] // auto-generated [ResourceExposure(ResourceScope.None)] [DllImport(JitHelpers.QCall, CharSet = CharSet.Unicode)] [SuppressUnmanagedCodeSecurity] private extern static SecurityZone _CreateFromUrl( String url ); #endif // FEATURE_CAS_POLICY public IPermission CreateIdentityPermission( Evidence evidence ) { return new ZoneIdentityPermission( SecurityZone ); } public SecurityZone SecurityZone { [System.Security.SecuritySafeCritical] // auto-generated get { #if FEATURE_CAS_POLICY if (m_url != null) m_zone = _CreateFromUrl( m_url ); #endif // FEATURE_CAS_POLICY return m_zone; } } public override bool Equals(Object o) { Zone other = o as Zone; if (other == null) { return false; } return SecurityZone == other.SecurityZone; } public override int GetHashCode() { return (int)SecurityZone; } public override EvidenceBase Clone() { return new Zone(this); } public Object Copy() { return Clone(); } #if FEATURE_CAS_POLICY internal SecurityElement ToXml() { SecurityElement elem = new SecurityElement( "System.Security.Policy.Zone" ); // If you hit this assert then most likely you are trying to change the name of this class. // This is ok as long as you change the hard coded string above and change the assert below. Contract.Assert( this.GetType().FullName.Equals( "System.Security.Policy.Zone" ), "Class name changed!" ); elem.AddAttribute( "version", "1" ); if (SecurityZone != SecurityZone.NoZone) elem.AddChild( new SecurityElement( "Zone", s_names[(int)SecurityZone] ) ); else elem.AddChild( new SecurityElement( "Zone", s_names[s_names.Length-1] ) ); return elem; } #endif // FEATURE_CAS_POLICY #if FEATURE_CAS_POLICY public override String ToString() { return ToXml().ToString(); } #endif // FEATURE_CAS_POLICY // INormalizeForIsolatedStorage is not implemented for startup perf // equivalent to INormalizeForIsolatedStorage.Normalize() internal Object Normalize() { return s_names[(int)SecurityZone]; } } } // 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
- SerializerWriterEventHandlers.cs
- CheckBoxList.cs
- ServiceDescriptionData.cs
- GlyphRun.cs
- Directory.cs
- UnsafeNativeMethods.cs
- HttpApplication.cs
- ProcessHostConfigUtils.cs
- ListMarkerSourceInfo.cs
- CodeSnippetStatement.cs
- RedistVersionInfo.cs
- IntSecurity.cs
- SplashScreenNativeMethods.cs
- RoutedEvent.cs
- SourceChangedEventArgs.cs
- EntityKey.cs
- ExtendLockAsyncResult.cs
- ActivityCodeGenerator.cs
- DataGridViewColumnStateChangedEventArgs.cs
- XhtmlBasicTextViewAdapter.cs
- SqlDuplicator.cs
- GraphicsPathIterator.cs
- ContextBase.cs
- JournalEntryListConverter.cs
- CornerRadiusConverter.cs
- DesignSurface.cs
- ThreadAbortException.cs
- ReflectTypeDescriptionProvider.cs
- ZipIOCentralDirectoryFileHeader.cs
- FixedDSBuilder.cs
- OdbcConnectionOpen.cs
- SQLDateTimeStorage.cs
- BlurBitmapEffect.cs
- SafeViewOfFileHandle.cs
- TransactionValidationBehavior.cs
- ButtonRenderer.cs
- DesignTimeTemplateParser.cs
- MenuBase.cs
- XmlArrayAttribute.cs
- UriSection.cs
- WebDescriptionAttribute.cs
- EventDescriptor.cs
- HMACSHA256.cs
- PrintingPermissionAttribute.cs
- EventHandlerList.cs
- XmlILModule.cs
- ResourceCollectionInfo.cs
- BufferedGraphicsManager.cs
- AnimationTimeline.cs
- ForAllOperator.cs
- LineInfo.cs
- PrintEvent.cs
- PrintDialog.cs
- LoggedException.cs
- UnsignedPublishLicense.cs
- ObjectStateFormatter.cs
- GetFileNameResult.cs
- Rotation3DAnimationBase.cs
- _ReceiveMessageOverlappedAsyncResult.cs
- PassportAuthenticationModule.cs
- BeginSelectCardRequest.cs
- TargetException.cs
- OpenTypeLayoutCache.cs
- baseaxisquery.cs
- RegexMatchCollection.cs
- NavigationCommands.cs
- XmlSerializerSection.cs
- DataGridAutoFormat.cs
- TypeSource.cs
- BStrWrapper.cs
- TimersDescriptionAttribute.cs
- TextFormatterContext.cs
- MarginsConverter.cs
- LingerOption.cs
- AlgoModule.cs
- XmlCustomFormatter.cs
- CalloutQueueItem.cs
- FontDriver.cs
- XmlNode.cs
- OdbcHandle.cs
- XmlToDatasetMap.cs
- DispatchChannelSink.cs
- HotSpotCollection.cs
- MarshalDirectiveException.cs
- DetailsViewInsertEventArgs.cs
- UnsafeNativeMethods.cs
- FontCacheUtil.cs
- ListBindableAttribute.cs
- EntityWithKeyStrategy.cs
- ConsumerConnectionPointCollection.cs
- PerformanceCounterLib.cs
- smtpconnection.cs
- Merger.cs
- RemoteWebConfigurationHostStream.cs
- OdbcRowUpdatingEvent.cs
- AdjustableArrowCap.cs
- UIElement3D.cs
- XmlRawWriter.cs
- QilList.cs
- OleDbEnumerator.cs