當前位置: 首頁>>代碼示例>>C#>>正文


C# EvaluationContext.AddClaimSet方法代碼示例

本文整理匯總了C#中System.IdentityModel.Policy.EvaluationContext.AddClaimSet方法的典型用法代碼示例。如果您正苦於以下問題:C# EvaluationContext.AddClaimSet方法的具體用法?C# EvaluationContext.AddClaimSet怎麽用?C# EvaluationContext.AddClaimSet使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.IdentityModel.Policy.EvaluationContext的用法示例。


在下文中一共展示了EvaluationContext.AddClaimSet方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Evaluate

        public bool Evaluate(EvaluationContext evaluationContext, ref object state)
        {
            IPrincipal principal = null;
            if (HttpContext.Current != null)
            {
                principal = HttpContext.Current.User;
            }

            if (principal != null)
            {
                // set the identity (for PrimaryIdentity)
                evaluationContext.Properties["Identities"] =
                    new List<IIdentity>() { principal.Identity };

                evaluationContext.Properties["Principal"] = principal;

                var nameClaim = Claim.CreateNameClaim(principal.Identity.Name);
                ClaimSet set;

                if (HttpContext.Current != null)
                {
                    set = new DefaultClaimSet(
                        nameClaim,
                        new Claim(ClaimTypes.Authentication, HttpContext.Current.User.Identity, Rights.Identity));
                }
                else
                {
                    set = new DefaultClaimSet(nameClaim);
                }

                evaluationContext.AddClaimSet(this, set);
            }

            return true;
        }
開發者ID:amido,項目名稱:Amido.PreProcessor,代碼行數:35,代碼來源:HttpContextIdentityPolicy.cs

示例2: Evaluate

        /**
        This method receives the claim sets evaluated so far by other authorization policies.
        For example, it may include a claim set for each token passed in the request message,
         * thus contain a WindowsClaimSet or UserNameClaimSet or x509 cliams set and so on.
         *
         * Responsible for inspecting claims based on the credentials provided,
         * mapping those claims to normalized claims,
         * and constructing a security principal for the request thread.
         *
         * The method should return false if this authorization policy was not able to complete its authorization.
         *
         * If false, the service model will invoke other authorization policies and then call this one once more, passing the updated claim sets.
         * This gives the authorization policy another chance to authorize calls.
         *
        **/
        public bool Evaluate(EvaluationContext evaluationContext, ref object state)
        {
            object obj;
            if (!evaluationContext.Properties.TryGetValue("Identities", out obj))
                return false;

            IList<IIdentity> identities = obj as IList<IIdentity>;
            if (obj == null || identities.Count <= 0)
                return false;

            IIdentity identity = identities[0];

            //This is claims conversion
            ClaimSet claims = MapClaims(identity);

            if (claims == null)
                return false;

            GenericPrincipal newPrincipal = new GenericPrincipal(identity, null);

            evaluationContext.Properties["Principal"] = newPrincipal;

            evaluationContext.AddClaimSet(this, claims);

            return true;
        }
開發者ID:cleancodenz,項目名稱:ServiceBus,代碼行數:41,代碼來源:MyClaimsAuthorizationPolicy.cs

示例3: Evaluate

 public bool Evaluate(EvaluationContext evaluationContext, ref object state)
 {
   evaluationContext.AddClaimSet(this, new DefaultClaimSet(Claim.CreateNameClaim(_principal.Identity.Name)));
   evaluationContext.Properties["Identities"] = new List<IIdentity>(new[] {_principal.Identity});
   evaluationContext.Properties["Principal"] = _principal;
   return true;
 }
開發者ID:yonglehou,項目名稱:DevDefined.OAuth,代碼行數:7,代碼來源:PrincipalAuthorizationPolicy.cs

示例4: foreach

        bool IAuthorizationPolicy.Evaluate( EvaluationContext evaluationContext, ref object state )
        {
            foreach ( ClaimSet issuance in _issuedClaimSets )
                evaluationContext.AddClaimSet( this, issuance );

            return true;
        }
開發者ID:Sn3b,項目名稱:Omniture-API,代碼行數:7,代碼來源:SecurityTokenAuthorizationPolicy.cs

示例5: Evaluate

        public bool Evaluate(EvaluationContext context, ref object state)
        {
            foreach (ClaimSet issuance in this.issuedClaimSets)
            {
                context.AddClaimSet(this, issuance);
            }

            return true;
        }
開發者ID:cleancodenz,項目名稱:ServiceBus,代碼行數:9,代碼來源:CreditCardTokenAuthorizationPolicy.cs

示例6:

 bool IAuthorizationPolicy.Evaluate( EvaluationContext evaluationContext, ref object state )
 {
     if ( evaluationContext == null )
     {
         throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull( "evaluationContext" );
     }
     evaluationContext.AddClaimSet( this, _issuer );
     return true;
 }
開發者ID:iskiselev,項目名稱:JSIL.NetFramework,代碼行數:9,代碼來源:SctAuthorizationPolicy.cs

示例7: Evaluate

        public bool Evaluate(EvaluationContext evaluationContext, ref object state)
        {
            bool bRet = false;
            CustomAuthState customstate = null;

            // If state is null, then we've not been called before so we need
            // to set up our custom state
            if (state == null)
            {
                customstate = new CustomAuthState();
                state = customstate;
            }
            else
                customstate = (CustomAuthState)state;

            Console.WriteLine("Inside MyAuthorizationPolicy::Evaluate");

            // If we've not added claims yet...
            if (!customstate.ClaimsAdded)
            {
                // Create an empty list of Claims
                IList<Claim> claims = new List<Claim>();

                // Iterate through each of the claimsets in the evaluation context
                foreach (ClaimSet cs in evaluationContext.ClaimSets)
                    // Look for Name claims in the current claimset...
                    foreach (Claim c in cs.FindClaims(ClaimTypes.Name, Rights.PossessProperty))
                        // Get the list of operations the given username is allowed to call...
                        foreach (string s in GetAllowedOpList(c.Resource.ToString()))
                        {
                            // Check numbers aren't too large
                            

                            // Add claims to the list
                            claims.Add(new Claim("http://example.org/claims/allowedoperation", s, Rights.PossessProperty));
                            Console.WriteLine("Claim added {0}", s);
                        }

                // Add claims to the evaluation context    
                evaluationContext.AddClaimSet(this, new DefaultClaimSet(this.Issuer, claims));

                // record that we've added claims
                customstate.ClaimsAdded = true;

                // return true, indicating we do not need to be called again.
                bRet = true;
            }
            else
            {
                // Should never get here, but just in case...
                bRet = true;
            }


            return bRet;
        }
開發者ID:ssickles,項目名稱:archive,代碼行數:56,代碼來源:MyAuthorizationPolicy.cs

示例8: Evaluate

        public bool Evaluate(EvaluationContext evaluationContext, ref object state)
        {
            // find identity
            Claim id = evaluationContext.ClaimSets.FindIdentityClaim();
            string userId = Map(id);

            evaluationContext.AddClaimSet(this, new CustomerClaimSet(userId, Issuer));

            return true;
        }
開發者ID:calderonsteven,項目名稱:Preparation_For_Exam70-513,代碼行數:10,代碼來源:CustomerAuthorizationPolicy.cs

示例9: Evaluate

        public bool Evaluate(EvaluationContext evaluationContext, ref object state)
        {
            Claim claim = Claim.CreateNameClaim(user.Identity.Name);
            evaluationContext.AddClaimSet(this, new DefaultClaimSet(claim));

            evaluationContext.Properties["Identities"] =
                new List<IIdentity>(new IIdentity[] { user.Identity });

            evaluationContext.Properties["Principal"] = user;

            return true;
        }
開發者ID:BorisMomtchev,項目名稱:NiCris.Dashboard-.NET-4.5,代碼行數:12,代碼來源:PrincipalAuthorizationPolicy.cs

示例10: Evaluate

        public bool Evaluate(EvaluationContext evaluationContext, ref object state)
        {
            if (evaluationContext.Properties.ContainsKey("Identities"))
            {
                IIdentity identity;
                ClaimSet claims = MapClaims(evaluationContext, out identity);
                
                CustomPrincipal newPrincipal = new CustomPrincipal(identity, claims);
                evaluationContext.Properties["Principal"] = newPrincipal;
                evaluationContext.AddClaimSet(this, claims);
            }
            return true;

        }
開發者ID:ssickles,項目名稱:archive,代碼行數:14,代碼來源:CustomAuthorizationPolicy.cs

示例11: Evaluate

        public bool Evaluate(EvaluationContext context, ref object state)
        {
            var identities = new List<IIdentity> {_identity};

            context.AddClaimSet(this,
                new DefaultClaimSet(Issuer, new Claim(ClaimTypes.Name, _identity == null ? null : _identity.Name, Rights.Identity)));

            if (context.Properties.ContainsKey(AuthContextIdentityPropertyName))
                context.Properties[AuthContextIdentityPropertyName] = identities;
            else
                context.Properties.Add(AuthContextIdentityPropertyName, identities);

            return true;
        }
開發者ID:richet,項目名稱:WcfRestContrib,代碼行數:14,代碼來源:IdentityAuthorizationPolicy.cs

示例12: Evaluate

        //We will add a custom claim to the EvaluationContext if the 'magic character' exists in the username
        public bool Evaluate(EvaluationContext evaluationContext, ref object state)
        {
            //Get the Identities Property
            object obj;
            if (!evaluationContext.Properties.TryGetValue("Identities", out obj))
            {
                Debug.WriteLine("CustomNameCheckerPolicy: Identities is null");
                return false;
            }

            //Get the list of IIdentities
            IList<IIdentity> identities = obj as IList<IIdentity>;
            if (identities == null || identities.Count != 1)
            {
                Debug.WriteLine("CustomNameCheckerPolicy: Identities.count = 0");
                return false;
            }

            //Get the WindowsIdentity
            //Any other type of IIdentity will cause it to return false
            WindowsIdentity wID = identities[0] as WindowsIdentity;
            if (wID == null)
            {
                Debug.WriteLine("CustomNameCheckerPolicy: Not a Windows Identity");
                return false;
            }

            //retrieve the username
            string[] domainAndUsername =  wID.Name.Split(new char[]{'\\'});
            string userName = domainAndUsername[0];
            if (domainAndUsername.Length > 1)
                userName = domainAndUsername[1];

            //Check to see if the 'magic character' exists in the username
            //Add our claim if it does
            if (userName.ToUpper().Contains(Constants.magicCharacter.ToUpper()))
            {
                List<Claim> claims = new List<Claim>(1);
                Claim magicCharacterClaim = new Claim(Constants.PossessesMagicCharacterType, Constants.magicCharacter, Rights.PossessProperty);
                claims.Add(magicCharacterClaim);
                evaluationContext.AddClaimSet(this, new DefaultClaimSet(claims));
            }

            return true;
        }
開發者ID:tian1ll1,項目名稱:WPF_Examples,代碼行數:46,代碼來源:CustomNameCheckerPolicy.cs

示例13: Evaluate

        public bool Evaluate(EvaluationContext evaluationContext, ref object state)
        {
            if (evaluationContext.Properties.ContainsKey("Identities"))
            {
                List<IIdentity> identities = evaluationContext.Properties["Identities"] as List<IIdentity>;
                IIdentity identity = identities.FirstOrDefault(i => i.AuthenticationType == "X509");
                
                GenericPrincipal genprincipal = new GenericPrincipal(identity, null);
                evaluationContext.Properties["Principal"] = genprincipal;

                var user = UserStore.GetUserByCertificate(identity.Name);
                evaluationContext.AddClaimSet(this, new DefaultClaimSet(new Claim("User", user, Rights.Identity)));

                return true;
            }
            else
                return false;
        }
開發者ID:kiszu,項目名稱:ForBlog,代碼行數:18,代碼來源:CustomCertificateAuthorizationPolicy.cs

示例14: Evaluate

			// This method is expected to be thread safe
			public bool Evaluate (EvaluationContext ec, ref object state)
			{
				lock (ec) {
					ec.AddClaimSet (this, CreateClaims ());
					List<IIdentity> list;
					if (!ec.Properties.ContainsKey ("Identities")) {
						list = new List<IIdentity> ();
						ec.Properties ["Identities"] = list;
					} else {
						IList<IIdentity> ilist = (IList<IIdentity>) ec.Properties ["Identities"];
						list = ilist as List<IIdentity>;
						if (list == null) {
							list = new List<IIdentity> (ilist);
							ec.Properties ["Identities"] = list;
						}
					}
					list.Add (CreateIdentity ());
					ec.RecordExpirationTime (DateTime.MaxValue.AddDays (-1));
				}
				// FIXME: is it correct that this should always return true?
				return true;
			}
開發者ID:nlhepler,項目名稱:mono,代碼行數:23,代碼來源:CustomUserNameSecurityTokenAuthenticator.cs

示例15: Evaluate

        /// <summary>
        /// Defines the set of rules to for authorizing a user given a set of claims. 
        /// It prepares the evaluation context with relevant information and adds the claims to the evaluation context.
        /// </summary>
        /// <param name="evaluationContext">Evaluation context</param>
        /// <param name="state">State</param>
        /// <returns>return false if this authorization policy was not able to complete its authorization, otherwise true</returns>
        public bool Evaluate(EvaluationContext evaluationContext, ref object state)
        {
            if (OperationContext.Current.IncomingMessageProperties[PRINCIPAL] != null)
            {
                IClaimsPrincipal principal = OperationContext.Current.IncomingMessageProperties[PRINCIPAL] as IClaimsPrincipal;

                // If the principal is not an IClaimsPrincipal we can not authorize it
                if (principal == null)
                {
                    return false;
                }

                evaluationContext.Properties[PRINCIPAL] = principal;

                if (principal.Claims != null)
                {
                    evaluationContext.AddClaimSet(this, principal.Claims);
                }

                return true;
            }
            return false;
        }
開發者ID:ognjenm,項目名稱:egle,代碼行數:30,代碼來源:ClaimsAuthorizationPolicy.cs


注:本文中的System.IdentityModel.Policy.EvaluationContext.AddClaimSet方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。