Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / Net / System / Net / Mail / smtppermission.cs / 1 / smtppermission.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Net.Mail { using System.Collections; using System.Security; using System.Security.Permissions; using System.Globalization; using System.Threading; ///public enum SmtpAccess { None = 0, Connect = 1, ConnectToUnrestrictedPort = 2}; /// [ AttributeUsage( AttributeTargets.Method | AttributeTargets.Constructor | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Assembly, AllowMultiple = true, Inherited = false )] [Serializable] public sealed class SmtpPermissionAttribute: CodeAccessSecurityAttribute { private const string strAccess = "Access"; private string access = null; /// public SmtpPermissionAttribute(SecurityAction action): base( action ) { } public string Access { get{ return access; } set{ access = value; } } /// public override IPermission CreatePermission() { SmtpPermission perm = null; if (Unrestricted) { perm = new SmtpPermission(PermissionState.Unrestricted); } else { perm = new SmtpPermission(PermissionState.None); if (access != null) { if (0 == string.Compare(access, "Connect", StringComparison.OrdinalIgnoreCase)) { perm.AddPermission(SmtpAccess.Connect); } else if (0 == string.Compare(access, "ConnectToUnrestrictedPort", StringComparison.OrdinalIgnoreCase)) { perm.AddPermission(SmtpAccess.ConnectToUnrestrictedPort); } else if (0 == string.Compare(access, "None", StringComparison.OrdinalIgnoreCase)) { perm.AddPermission(SmtpAccess.None); } else { throw new ArgumentException(SR.GetString(SR.net_perm_invalid_val, strAccess, access)); } } } return perm; } } /// [Serializable] public sealed class SmtpPermission: CodeAccessPermission, IUnrestrictedPermission { SmtpAccess access; private bool unrestricted; /// public SmtpPermission(PermissionState state) { if (state == PermissionState.Unrestricted){ access = SmtpAccess.ConnectToUnrestrictedPort; unrestricted = true; } else{ access = SmtpAccess.None; } } public SmtpPermission(bool unrestricted) { if (unrestricted){ access = SmtpAccess.ConnectToUnrestrictedPort; this.unrestricted = true; } else{ access = SmtpAccess.None; } } /// public SmtpPermission(SmtpAccess access) { this.access = access; } public SmtpAccess Access { get{ return access; } } /// public void AddPermission(SmtpAccess access) { if (access > this.access) this.access = access; } /// public bool IsUnrestricted() { return unrestricted; } /// public override IPermission Copy() { if(unrestricted){ return new SmtpPermission(true); } return new SmtpPermission(access); } /// public override IPermission Union(IPermission target) { if (target==null) { return this.Copy(); } SmtpPermission other = target as SmtpPermission; if(other == null) { throw new ArgumentException(SR.GetString(SR.net_perm_target), "target"); } if(unrestricted || other.IsUnrestricted()){ return new SmtpPermission(true); } return new SmtpPermission(this.access > other.access ? this.access : other.access); } /// public override IPermission Intersect(IPermission target) { if (target == null) { return null; } SmtpPermission other = target as SmtpPermission; if(other == null) { throw new ArgumentException(SR.GetString(SR.net_perm_target), "target"); } if(IsUnrestricted() && other.IsUnrestricted()){ return new SmtpPermission(true); } return new SmtpPermission(this.access < other.access ? this.access : other.access); } /// public override bool IsSubsetOf(IPermission target) { // Pattern suggested by security engine if (target == null) { return (access == SmtpAccess.None); } SmtpPermission other = target as SmtpPermission; if (other == null) { throw new ArgumentException(SR.GetString(SR.net_perm_target), "target"); } if(unrestricted && !other.IsUnrestricted()){ return false; } return (other.access >= access); } /// public override void FromXml(SecurityElement securityElement) { if (securityElement == null) { throw new ArgumentNullException("securityElement"); } if (!securityElement.Tag.Equals("IPermission")) { throw new ArgumentException(SR.GetString(SR.net_not_ipermission), "securityElement"); } string className = securityElement.Attribute("class"); if (className == null) { throw new ArgumentException(SR.GetString(SR.net_no_classname), "securityElement"); } if (className.IndexOf(this.GetType().FullName) < 0) { throw new ArgumentException(SR.GetString(SR.net_no_typename), "securityElement"); } String str = securityElement.Attribute("Unrestricted"); if (str != null) { if (0 == string.Compare( str, "true", StringComparison.OrdinalIgnoreCase)){ access = SmtpAccess.ConnectToUnrestrictedPort; unrestricted = true; return; } } str = securityElement.Attribute("Access"); if (str != null) { if(0 == string.Compare(str, "Connect", StringComparison.OrdinalIgnoreCase)){ access = SmtpAccess.Connect; } else if(0 == string.Compare(str, "ConnectToUnrestrictedPort", StringComparison.OrdinalIgnoreCase)){ access = SmtpAccess.ConnectToUnrestrictedPort; } else if(0 == string.Compare(str, "None", StringComparison.OrdinalIgnoreCase)){ access = SmtpAccess.None; } else{ throw new ArgumentException(SR.GetString(SR.net_perm_invalid_val_in_element), "Access"); } } } /// public override SecurityElement ToXml() { SecurityElement securityElement = new SecurityElement( "IPermission" ); securityElement.AddAttribute("class", this.GetType().FullName + ", " + this.GetType().Module.Assembly.FullName.Replace( '\"', '\'' )); securityElement.AddAttribute("version", "1"); if(unrestricted){ securityElement.AddAttribute("Unrestricted", "true"); return securityElement; } if (access == SmtpAccess.Connect) { securityElement.AddAttribute("Access", "Connect"); } else if (access == SmtpAccess.ConnectToUnrestrictedPort) { securityElement.AddAttribute("Access", "ConnectToUnrestrictedPort"); } return securityElement; } }// class SmtpPermission } // namespace System.Net // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Net.Mail { using System.Collections; using System.Security; using System.Security.Permissions; using System.Globalization; using System.Threading; ///public enum SmtpAccess { None = 0, Connect = 1, ConnectToUnrestrictedPort = 2}; /// [ AttributeUsage( AttributeTargets.Method | AttributeTargets.Constructor | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Assembly, AllowMultiple = true, Inherited = false )] [Serializable] public sealed class SmtpPermissionAttribute: CodeAccessSecurityAttribute { private const string strAccess = "Access"; private string access = null; /// public SmtpPermissionAttribute(SecurityAction action): base( action ) { } public string Access { get{ return access; } set{ access = value; } } /// public override IPermission CreatePermission() { SmtpPermission perm = null; if (Unrestricted) { perm = new SmtpPermission(PermissionState.Unrestricted); } else { perm = new SmtpPermission(PermissionState.None); if (access != null) { if (0 == string.Compare(access, "Connect", StringComparison.OrdinalIgnoreCase)) { perm.AddPermission(SmtpAccess.Connect); } else if (0 == string.Compare(access, "ConnectToUnrestrictedPort", StringComparison.OrdinalIgnoreCase)) { perm.AddPermission(SmtpAccess.ConnectToUnrestrictedPort); } else if (0 == string.Compare(access, "None", StringComparison.OrdinalIgnoreCase)) { perm.AddPermission(SmtpAccess.None); } else { throw new ArgumentException(SR.GetString(SR.net_perm_invalid_val, strAccess, access)); } } } return perm; } } /// [Serializable] public sealed class SmtpPermission: CodeAccessPermission, IUnrestrictedPermission { SmtpAccess access; private bool unrestricted; /// public SmtpPermission(PermissionState state) { if (state == PermissionState.Unrestricted){ access = SmtpAccess.ConnectToUnrestrictedPort; unrestricted = true; } else{ access = SmtpAccess.None; } } public SmtpPermission(bool unrestricted) { if (unrestricted){ access = SmtpAccess.ConnectToUnrestrictedPort; this.unrestricted = true; } else{ access = SmtpAccess.None; } } /// public SmtpPermission(SmtpAccess access) { this.access = access; } public SmtpAccess Access { get{ return access; } } /// public void AddPermission(SmtpAccess access) { if (access > this.access) this.access = access; } /// public bool IsUnrestricted() { return unrestricted; } /// public override IPermission Copy() { if(unrestricted){ return new SmtpPermission(true); } return new SmtpPermission(access); } /// public override IPermission Union(IPermission target) { if (target==null) { return this.Copy(); } SmtpPermission other = target as SmtpPermission; if(other == null) { throw new ArgumentException(SR.GetString(SR.net_perm_target), "target"); } if(unrestricted || other.IsUnrestricted()){ return new SmtpPermission(true); } return new SmtpPermission(this.access > other.access ? this.access : other.access); } /// public override IPermission Intersect(IPermission target) { if (target == null) { return null; } SmtpPermission other = target as SmtpPermission; if(other == null) { throw new ArgumentException(SR.GetString(SR.net_perm_target), "target"); } if(IsUnrestricted() && other.IsUnrestricted()){ return new SmtpPermission(true); } return new SmtpPermission(this.access < other.access ? this.access : other.access); } /// public override bool IsSubsetOf(IPermission target) { // Pattern suggested by security engine if (target == null) { return (access == SmtpAccess.None); } SmtpPermission other = target as SmtpPermission; if (other == null) { throw new ArgumentException(SR.GetString(SR.net_perm_target), "target"); } if(unrestricted && !other.IsUnrestricted()){ return false; } return (other.access >= access); } /// public override void FromXml(SecurityElement securityElement) { if (securityElement == null) { throw new ArgumentNullException("securityElement"); } if (!securityElement.Tag.Equals("IPermission")) { throw new ArgumentException(SR.GetString(SR.net_not_ipermission), "securityElement"); } string className = securityElement.Attribute("class"); if (className == null) { throw new ArgumentException(SR.GetString(SR.net_no_classname), "securityElement"); } if (className.IndexOf(this.GetType().FullName) < 0) { throw new ArgumentException(SR.GetString(SR.net_no_typename), "securityElement"); } String str = securityElement.Attribute("Unrestricted"); if (str != null) { if (0 == string.Compare( str, "true", StringComparison.OrdinalIgnoreCase)){ access = SmtpAccess.ConnectToUnrestrictedPort; unrestricted = true; return; } } str = securityElement.Attribute("Access"); if (str != null) { if(0 == string.Compare(str, "Connect", StringComparison.OrdinalIgnoreCase)){ access = SmtpAccess.Connect; } else if(0 == string.Compare(str, "ConnectToUnrestrictedPort", StringComparison.OrdinalIgnoreCase)){ access = SmtpAccess.ConnectToUnrestrictedPort; } else if(0 == string.Compare(str, "None", StringComparison.OrdinalIgnoreCase)){ access = SmtpAccess.None; } else{ throw new ArgumentException(SR.GetString(SR.net_perm_invalid_val_in_element), "Access"); } } } /// public override SecurityElement ToXml() { SecurityElement securityElement = new SecurityElement( "IPermission" ); securityElement.AddAttribute("class", this.GetType().FullName + ", " + this.GetType().Module.Assembly.FullName.Replace( '\"', '\'' )); securityElement.AddAttribute("version", "1"); if(unrestricted){ securityElement.AddAttribute("Unrestricted", "true"); return securityElement; } if (access == SmtpAccess.Connect) { securityElement.AddAttribute("Access", "Connect"); } else if (access == SmtpAccess.ConnectToUnrestrictedPort) { securityElement.AddAttribute("Access", "ConnectToUnrestrictedPort"); } return securityElement; } }// class SmtpPermission } // namespace System.Net // 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
- CacheRequest.cs
- UICuesEvent.cs
- WorkflowMarkupSerializer.cs
- DataGridViewLinkCell.cs
- ChannelSinkStacks.cs
- DataGridViewImageCell.cs
- ServerReliableChannelBinder.cs
- ProcessRequestArgs.cs
- CompensationDesigner.cs
- SqlDataSourceConfigureFilterForm.cs
- TaskFileService.cs
- IpcServerChannel.cs
- ManipulationDeltaEventArgs.cs
- PeerTransportCredentialType.cs
- SettingsSavedEventArgs.cs
- DelegateHelpers.cs
- ExpressionBindings.cs
- HttpWriter.cs
- MetadataExporter.cs
- DefaultPrintController.cs
- GridViewColumn.cs
- SqlTriggerContext.cs
- DocumentPage.cs
- XmlUtil.cs
- ChameleonKey.cs
- LogicalTreeHelper.cs
- List.cs
- StateMachine.cs
- ToolBarOverflowPanel.cs
- MobileControlsSectionHelper.cs
- WriteableBitmap.cs
- FormViewPagerRow.cs
- WebPartMenuStyle.cs
- Context.cs
- TextEditorParagraphs.cs
- ModuleConfigurationInfo.cs
- DetailsViewRow.cs
- SqlRecordBuffer.cs
- ProfileManager.cs
- SamlAdvice.cs
- assertwrapper.cs
- Transform3DGroup.cs
- DesignerOptionService.cs
- PageContentAsyncResult.cs
- CompositeKey.cs
- TextTreeInsertElementUndoUnit.cs
- MissingSatelliteAssemblyException.cs
- SemanticKeyElement.cs
- SoapIncludeAttribute.cs
- ProviderBase.cs
- WindowsSecurityTokenAuthenticator.cs
- Array.cs
- TraceContextEventArgs.cs
- EntityAdapter.cs
- SubqueryRules.cs
- LocalFileSettingsProvider.cs
- HtmlControlPersistable.cs
- ProtocolsConfigurationEntry.cs
- HybridDictionary.cs
- Object.cs
- UnsafeNativeMethods.cs
- UnionExpr.cs
- XmlSchemaParticle.cs
- DtcInterfaces.cs
- DataGridViewCellCollection.cs
- XmlObjectSerializerWriteContextComplex.cs
- DiagnosticStrings.cs
- SqlUserDefinedTypeAttribute.cs
- BuilderPropertyEntry.cs
- InputElement.cs
- WorkflowApplicationAbortedException.cs
- AdornerLayer.cs
- DbLambda.cs
- XPathAncestorQuery.cs
- ServerProtocol.cs
- Accessible.cs
- UIElementPropertyUndoUnit.cs
- Ops.cs
- Method.cs
- TrackingProfileSerializer.cs
- TemplateXamlParser.cs
- HierarchicalDataSourceControl.cs
- PathSegmentCollection.cs
- WebPermission.cs
- HtmlObjectListAdapter.cs
- NeedSkipTokenVisitor.cs
- SAPIEngineTypes.cs
- ConnectionConsumerAttribute.cs
- HtmlListAdapter.cs
- UInt16.cs
- SystemNetworkInterface.cs
- SecurityTokenAuthenticator.cs
- JumpTask.cs
- SafeLibraryHandle.cs
- TaiwanCalendar.cs
- DataGridViewLinkCell.cs
- SelectionProcessor.cs
- EntityDescriptor.cs
- PrintPreviewGraphics.cs
- ECDiffieHellmanCngPublicKey.cs