Inheritance: CodeAccessSecurityAttribute
コード例 #1
0
		static bool TryProcessPermissionSetAttribute (SecurityDeclaration declaration, out PermissionSet set)
		{
			set = null;

			if (!declaration.HasSecurityAttributes && declaration.SecurityAttributes.Count != 1)
				return false;

			var security_attribute = declaration.SecurityAttributes [0];
			if (!security_attribute.AttributeType.IsTypeOf ("System.Security.Permissions", "PermissionSetAttribute"))
				return false;

			var attribute = new SSP.PermissionSetAttribute ((SSP.SecurityAction) declaration.Action);

			var named_argument = security_attribute.Properties [0];
			string value = (string) named_argument.Argument.Value;
			switch (named_argument.Name) {
			case "XML":
				attribute.XML = value;
				break;
			case "Name":
				attribute.Name = value;
				break;
			default:
				throw new NotImplementedException (named_argument.Name);
			}

			set = attribute.CreatePermissionSet ();
			return true;
		}
コード例 #2
0
        static bool TryProcessPermissionSetAttribute(SecurityDeclaration declaration, out PermissionSet set)
        {
            set = null;

            if (!declaration.HasSecurityAttributes && declaration.SecurityAttributes.Count != 1)
            {
                return(false);
            }

            var security_attribute = declaration.SecurityAttributes [0];

            if (!security_attribute.AttributeType.IsTypeOf("System.Security.Permissions", "PermissionSetAttribute"))
            {
                return(false);
            }

            var named_argument = security_attribute.Properties [0];

            if (named_argument.Name != "XML")
            {
                throw new NotSupportedException();
            }

            var attribute = new SSP.PermissionSetAttribute((SSP.SecurityAction)declaration.Action);

            attribute.XML = (string)named_argument.Argument.Value;

            set = attribute.CreatePermissionSet();
            return(true);
        }
コード例 #3
0
		public void Action ()
		{
			PermissionSetAttribute a = new PermissionSetAttribute (SecurityAction.Assert);
			Assert.AreEqual (SecurityAction.Assert, a.Action, "Action=Assert");
			a.Action = SecurityAction.Demand;
			Assert.AreEqual (SecurityAction.Demand, a.Action, "Action=Demand");
			a.Action = SecurityAction.Deny;
			Assert.AreEqual (SecurityAction.Deny, a.Action, "Action=Deny");
			a.Action = SecurityAction.InheritanceDemand;
			Assert.AreEqual (SecurityAction.InheritanceDemand, a.Action, "Action=InheritanceDemand");
			a.Action = SecurityAction.LinkDemand;
			Assert.AreEqual (SecurityAction.LinkDemand, a.Action, "Action=LinkDemand");
			a.Action = SecurityAction.PermitOnly;
			Assert.AreEqual (SecurityAction.PermitOnly, a.Action, "Action=PermitOnly");
			a.Action = SecurityAction.RequestMinimum;
			Assert.AreEqual (SecurityAction.RequestMinimum, a.Action, "Action=RequestMinimum");
			a.Action = SecurityAction.RequestOptional;
			Assert.AreEqual (SecurityAction.RequestOptional, a.Action, "Action=RequestOptional");
			a.Action = SecurityAction.RequestRefuse;
			Assert.AreEqual (SecurityAction.RequestRefuse, a.Action, "Action=RequestRefuse");
#if NET_2_0
			a.Action = SecurityAction.DemandChoice;
			Assert.AreEqual (SecurityAction.DemandChoice, a.Action, "Action=DemandChoice");
			a.Action = SecurityAction.InheritanceDemandChoice;
			Assert.AreEqual (SecurityAction.InheritanceDemandChoice, a.Action, "Action=InheritanceDemandChoice");
			a.Action = SecurityAction.LinkDemandChoice;
			Assert.AreEqual (SecurityAction.LinkDemandChoice, a.Action, "Action=LinkDemandChoice");
#endif
		}
コード例 #4
0
		static bool TryProcessPermissionSetAttribute (SecurityDeclaration declaration, out PermissionSet set)
		{
			set = null;

			if (!declaration.HasSecurityAttributes)
				return false;

			var attributes = declaration.SecurityAttributes;
			if (attributes.Count != 1)
				return false;

			var security_attribute = attributes [0];
			var attribute_type = security_attribute.AttributeType;
			if (attribute_type.Name != "PermissionSetAttribute" || attribute_type.Namespace != "System.Security.Permissions")
				return false;

			var attribute = new SSP.PermissionSetAttribute ((SSP.SecurityAction) declaration.Action);

			foreach (var named_argument in security_attribute.Properties) {
				object value = named_argument.Argument.Value;
				switch (named_argument.Name) {
				case "Unrestricted":
					attribute.Unrestricted = (bool) value;
					break;
				case "UnicodeEncoded":
					attribute.UnicodeEncoded = (bool) value;
					break;
				case "XML":
					attribute.XML = (string) value;
					break;
				case "Name":
					attribute.Name = (string) value;
					break;
				case "File":
					attribute.File = (string) value;
					break;
				case "Hex":
					attribute.Hex = (string) value;
					break;
				default:
					throw new NotImplementedException (named_argument.Name);
				}
			}

			set = attribute.CreatePermissionSet ();
			return true;
		}
コード例 #5
0
		public void Default () 
		{
			PermissionSetAttribute a = new PermissionSetAttribute (SecurityAction.Assert);
			Assert.IsNull (a.File, "File");
			Assert.IsNull (a.Hex, "Hex");
			Assert.IsNull (a.Name, "Name");
			Assert.IsNull (a.XML, "XML");
			Assert.IsFalse (a.UnicodeEncoded, "UnicodeEncoded");
			Assert.AreEqual (a.ToString (), a.TypeId.ToString (), "TypeId");
			Assert.IsFalse (a.Unrestricted, "Unrestricted");

			IPermission perm = a.CreatePermission ();
			Assert.IsNull (perm, "CreatePermission");

			PermissionSet ps = a.CreatePermissionSet ();
			Assert.AreEqual (0, ps.Count, "CreatePermissionSet");
		}
コード例 #6
0
        static bool TryProcessPermissionSetAttribute(SecurityDeclaration declaration, out PermissionSet set)
        {
            set = null;

            if (!declaration.HasSecurityAttributes && declaration.SecurityAttributes.Count != 1)
            {
                return(false);
            }

            var security_attribute = declaration.SecurityAttributes [0];

            if (!security_attribute.AttributeType.IsTypeOf("System.Security.Permissions", "PermissionSetAttribute"))
            {
                return(false);
            }

            var attribute = new SSP.PermissionSetAttribute((SSP.SecurityAction)declaration.Action);

            var    named_argument = security_attribute.Properties [0];
            string value          = (string)named_argument.Argument.Value;

            switch (named_argument.Name)
            {
            case "XML":
                attribute.XML = value;
                break;

            case "Name":
                attribute.Name = value;
                break;

            default:
                throw new NotImplementedException(named_argument.Name);
            }

            set = attribute.CreatePermissionSet();
            return(true);
        }
コード例 #7
0
ファイル: permview.cs プロジェクト: nobled/mono
		static bool TryProcessPermissionSetAttribute (SecurityDeclaration declaration, out PermissionSet set)
		{
			set = null;

			if (!declaration.HasSecurityAttributes && declaration.SecurityAttributes.Count != 1)
				return false;

			var security_attribute = declaration.SecurityAttributes [0];
			var attribute_type = security_attribute.AttributeType;

			if (attribute_type.Name != "PermissionSetAttribute" || attribute_type.Namespace != "System.Security.Permissions")
				return false;

			var named_argument = security_attribute.Properties [0];
			if (named_argument.Name != "XML")
				throw new NotSupportedException ();

			var attribute = new SSP.PermissionSetAttribute ((SSP.SecurityAction) declaration.Action);
			attribute.XML = (string) named_argument.Argument.Value;

			set = attribute.CreatePermissionSet ();
			return true;
		}
コード例 #8
0
		public void File () 
		{
			PermissionSetAttribute a = new PermissionSetAttribute (SecurityAction.Assert);
			a.File = "mono";
			Assert.AreEqual ("mono", a.File, "File");
#if NET_2_0
			Assert.IsNull (a.Hex, "Hex");
#endif
			Assert.IsNull (a.Name, "Name");
			Assert.IsNull (a.XML, "XML");
			a.File = null;
			Assert.IsNull (a.File, "File");
#if NET_2_0
			Assert.IsNull (a.Hex, "Hex");
#endif
			Assert.IsNull (a.Name, "Name");
			Assert.IsNull (a.XML, "XML");
		}
コード例 #9
0
		public void Action_Invalid ()
		{
			PermissionSetAttribute a = new PermissionSetAttribute ((SecurityAction)Int32.MinValue);
			// no validation in attribute
		}
コード例 #10
0
		public void Unrestricted () 
		{
			PermissionSetAttribute a = new PermissionSetAttribute (SecurityAction.Assert);
			a.Unrestricted = true;
			Assert.IsNull (a.File, "File");
#if NET_2_0
			Assert.IsNull (a.Hex, "Hex");
#endif
			Assert.IsNull (a.Name, "Name");
			Assert.IsNull (a.XML, "XML");

			PermissionSet ps = a.CreatePermissionSet ();
			Assert.IsTrue (ps.IsUnrestricted (), "CreatePermissionSet.IsUnrestricted");
		}
コード例 #11
0
		public void UnicodeEncoded () 
		{
			PermissionSetAttribute a = new PermissionSetAttribute (SecurityAction.Assert);
			a.UnicodeEncoded = true;
			Assert.IsTrue (a.UnicodeEncoded, "UnicodeEncoded-true");
			a.UnicodeEncoded = false;
			Assert.IsFalse (a.UnicodeEncoded, "UnicodeEncoded-false");
		}
コード例 #12
0
		public void Hex_BigEndianUnicode_Permission ()
		{
			SecurityPermission sp = new SecurityPermission (SecurityPermissionFlag.Assertion);
			PermissionSet ps = new PermissionSet (PermissionState.None);
			ps.AddPermission (sp);

			PermissionSetAttribute a = new PermissionSetAttribute (SecurityAction.Assert);
			a.UnicodeEncoded = true;
			a.Hex = "003C005000650072006D0069007300730069006F006E00530065007400200063006C006100730073003D002200530079007300740065006D002E00530065006300750072006900740079002E005000650072006D0069007300730069006F006E0053006500740022000D000A00760065007200730069006F006E003D002200310022003E000D000A003C0049005000650072006D0069007300730069006F006E00200063006C006100730073003D002200530079007300740065006D002E00530065006300750072006900740079002E005000650072006D0069007300730069006F006E0073002E00530065006300750072006900740079005000650072006D0069007300730069006F006E002C0020006D00730063006F0072006C00690062002C002000560065007200730069006F006E003D0032002E0030002E0033003600300030002E0030002C002000430075006C0074007500720065003D006E00650075007400720061006C002C0020005000750062006C00690063004B006500790054006F006B0065006E003D00620037003700610035006300350036003100390033003400650030003800390022000D000A00760065007200730069006F006E003D002200310022000D000A0046006C006100670073003D00220041007300730065007200740069006F006E0022002F003E000D000A003C002F005000650072006D0069007300730069006F006E005300650074003E000D000";
			PermissionSet psbeu = a.CreatePermissionSet ();
			Assert.IsTrue (ps.Equals (psbeu), "HEX-BIGENDIAN-UNICODE");
		}
コード例 #13
0
		public void Hex_ASCII_Permission ()
		{
			SecurityPermission sp = new SecurityPermission (SecurityPermissionFlag.Assertion);
			PermissionSet ps = new PermissionSet (PermissionState.None);
			ps.AddPermission (sp);

			PermissionSetAttribute a = new PermissionSetAttribute (SecurityAction.Assert);
			a.Hex = "3C5065726D697373696F6E53657420636C6173733D2253797374656D2E53656375726974792E5065726D697373696F6E536574220D0A76657273696F6E3D2231223E0D0A3C495065726D697373696F6E20636C6173733D2253797374656D2E53656375726974792E5065726D697373696F6E732E53656375726974795065726D697373696F6E2C206D73636F726C69622C2056657273696F6E3D322E302E333630302E302C2043756C747572653D6E65757472616C2C205075626C69634B6579546F6B656E3D62373761356335363139333465303839220D0A76657273696F6E3D2231220D0A466C6167733D22417373657274696F6E222F3E0D0A3C2F5065726D697373696F6E5365743E0D0A";
			PermissionSet psa = a.CreatePermissionSet ();
			Assert.IsTrue (ps.Equals (psa), "HEX-ASCII");
		}
コード例 #14
0
		public void Hex ()
		{
			PermissionSetAttribute a = new PermissionSetAttribute (SecurityAction.Assert);
			Assert.IsNull (a.Hex, "Hex-1");
			a.Hex = String.Empty;
			Assert.AreEqual (String.Empty, a.Hex, "Hex-2");
			a.Hex = null;
			Assert.IsNull (a.Hex, "Hex-3");
		}
コード例 #15
0
        static bool TryProcessPermissionSetAttribute(SecurityDeclaration declaration, out PermissionSet set)
        {
            set = null;

            if (!declaration.HasSecurityAttributes)
            {
                return(false);
            }

            var attributes = declaration.SecurityAttributes;

            if (attributes.Count != 1)
            {
                return(false);
            }

            var security_attribute = attributes [0];
            var attribute_type     = security_attribute.AttributeType;

            if (attribute_type.Name != "PermissionSetAttribute" || attribute_type.Namespace != "System.Security.Permissions")
            {
                return(false);
            }

            var attribute = new SSP.PermissionSetAttribute((SSP.SecurityAction)declaration.Action);

            foreach (var named_argument in security_attribute.Properties)
            {
                object value = named_argument.Argument.Value;
                switch (named_argument.Name)
                {
                case "Unrestricted":
                    attribute.Unrestricted = (bool)value;
                    break;

                case "UnicodeEncoded":
                    attribute.UnicodeEncoded = (bool)value;
                    break;

                case "XML":
                    attribute.XML = (string)value;
                    break;

                case "Name":
                    attribute.Name = (string)value;
                    break;

                case "File":
                    attribute.File = (string)value;
                    break;

                case "Hex":
                    attribute.Hex = (string)value;
                    break;

                default:
                    throw new NotImplementedException(named_argument.Name);
                }
            }

            set = attribute.CreatePermissionSet();
            return(true);
        }
コード例 #16
0
		private void Unification (string xml)
		{
			PermissionSetAttribute psa = new PermissionSetAttribute (SecurityAction.Assert);
			psa.XML = xml;
			string pset = psa.CreatePermissionSet ().ToString ();
			string currentVersion = typeof (string).Assembly.GetName ().Version.ToString ();
			Assert.IsTrue (pset.IndexOf (currentVersion) > 0, currentVersion);
		}
コード例 #17
0
		public void Hex_Bad ()
		{
			PermissionSetAttribute a = new PermissionSetAttribute (SecurityAction.Assert);
			a.Hex = "g";
			Assert.AreEqual ("g", a.Hex, "Bad Hex");
			a.CreatePermissionSet ();
		}