//------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //------------------------------------------------------------------------------ namespace System.Web { using System.Security; using System.Security.Permissions; using System.Globalization; //NOTE: While AspNetHostingPermissionAttribute resides in System.DLL, // no classes from that DLL are able to make declarative usage of AspNetHostingPermission. [Serializable] public enum AspNetHostingPermissionLevel { None = 100, Minimal = 200, Low = 300, Medium = 400, High = 500, Unrestricted = 600 } [AttributeUsage(AttributeTargets.All, AllowMultiple=true, Inherited=false )] [Serializable] sealed public class AspNetHostingPermissionAttribute : CodeAccessSecurityAttribute { AspNetHostingPermissionLevel _level; public AspNetHostingPermissionAttribute ( SecurityAction action ) : base( action ) { _level = AspNetHostingPermissionLevel.None; } public AspNetHostingPermissionLevel Level { get { return _level; } set { AspNetHostingPermission.VerifyAspNetHostingPermissionLevel(value, "Level"); _level = value; } } public override IPermission CreatePermission() { if (Unrestricted) { return new AspNetHostingPermission(PermissionState.Unrestricted); } else { return new AspNetHostingPermission(_level); } } } /// /// /// /// [Serializable] public sealed class AspNetHostingPermission : CodeAccessPermission, IUnrestrictedPermission { AspNetHostingPermissionLevel _level; static internal void VerifyAspNetHostingPermissionLevel(AspNetHostingPermissionLevel level, string arg) { switch (level) { case AspNetHostingPermissionLevel.Unrestricted: case AspNetHostingPermissionLevel.High: case AspNetHostingPermissionLevel.Medium: case AspNetHostingPermissionLevel.Low: case AspNetHostingPermissionLevel.Minimal: case AspNetHostingPermissionLevel.None: break; default: throw new ArgumentException(arg); } } /// /// /// Creates a new instance of the System.Net.AspNetHostingPermission /// class that passes all demands or that fails all demands. /// /// public AspNetHostingPermission(PermissionState state) { switch (state) { case PermissionState.Unrestricted: _level = AspNetHostingPermissionLevel.Unrestricted; break; case PermissionState.None: _level = AspNetHostingPermissionLevel.None; break; default: throw new ArgumentException(SR.GetString(SR.InvalidArgument, state.ToString(), "state")); } } public AspNetHostingPermission(AspNetHostingPermissionLevel level) { VerifyAspNetHostingPermissionLevel(level, "level"); _level = level; } public AspNetHostingPermissionLevel Level { get { return _level; } set { VerifyAspNetHostingPermissionLevel(value, "Level"); _level = value; } } // IUnrestrictedPermission interface methods /// /// /// Checks the overall permission state of the object. /// /// public bool IsUnrestricted() { return _level == AspNetHostingPermissionLevel.Unrestricted; } // IPermission interface methods /// /// /// Creates a copy of a System.Net.AspNetHostingPermission /// /// public override IPermission Copy () { return new AspNetHostingPermission(_level); } /// /// Returns the logical union between two System.Net.AspNetHostingPermission instances. /// public override IPermission Union(IPermission target) { if (target == null) { return Copy(); } if (target.GetType() != typeof(AspNetHostingPermission)) { throw new ArgumentException(SR.GetString(SR.InvalidArgument, target == null ? "null" : target.ToString(), "target")); } AspNetHostingPermission other = (AspNetHostingPermission) target; if (Level >= other.Level) { return new AspNetHostingPermission(Level); } else { return new AspNetHostingPermission(other.Level); } } /// /// Returns the logical intersection between two System.Net.AspNetHostingPermission instances. /// public override IPermission Intersect(IPermission target) { if (target == null) { return null; } if (target.GetType() != typeof(AspNetHostingPermission)) { throw new ArgumentException(SR.GetString(SR.InvalidArgument, target == null ? "null" : target.ToString(), "target")); } AspNetHostingPermission other = (AspNetHostingPermission) target; if (Level <= other.Level) { return new AspNetHostingPermission(Level); } else { return new AspNetHostingPermission(other.Level); } } /// /// Compares two System.Net.AspNetHostingPermission instances. /// public override bool IsSubsetOf(IPermission target) { if (target == null) { return _level == AspNetHostingPermissionLevel.None; } if (target.GetType() != typeof(AspNetHostingPermission)) { throw new ArgumentException(SR.GetString(SR.InvalidArgument, target == null ? "null" : target.ToString(), "target")); } AspNetHostingPermission other = (AspNetHostingPermission) target; return Level <= other.Level; } /// /// public override void FromXml(SecurityElement securityElement) { if (securityElement == null) { throw new ArgumentNullException(SR.GetString(SR.AspNetHostingPermissionBadXml,"securityElement")); } if (!securityElement.Tag.Equals("IPermission")) { throw new ArgumentException(SR.GetString(SR.AspNetHostingPermissionBadXml,"securityElement")); } string className = securityElement.Attribute("class"); if (className == null) { throw new ArgumentException(SR.GetString(SR.AspNetHostingPermissionBadXml,"securityElement")); } if (className.IndexOf(this.GetType().FullName, StringComparison.Ordinal) < 0) { throw new ArgumentException(SR.GetString(SR.AspNetHostingPermissionBadXml,"securityElement")); } string version = securityElement.Attribute("version"); if (string.Compare(version, "1", StringComparison.OrdinalIgnoreCase) != 0) { throw new ArgumentException(SR.GetString(SR.AspNetHostingPermissionBadXml,"version")); } string level = securityElement.Attribute("Level"); if (level == null) { _level = AspNetHostingPermissionLevel.None; } else { _level = (AspNetHostingPermissionLevel) Enum.Parse(typeof(AspNetHostingPermissionLevel), level); } } /// /// [To be supplied.] /// 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" ); securityElement.AddAttribute("Level", Enum.GetName(typeof(AspNetHostingPermissionLevel), _level)); if (IsUnrestricted()) { securityElement.AddAttribute("Unrestricted", "true"); } return securityElement; } } }