AD FS troubleshooting - claims rules syntax

A claim is a statement that one subject makes about itself or another subject. Claims are issued by a relying party, and they're given one or more values and then packaged in security tokens that are issued by the AD FS server. This article deals with the claims syntax and creation. For information on claims issuance see AD FS Troubleshooting - Claims Issuance.

How claim rules are processed

Claim rules are processed through the claims pipeline using the claims engine. The claims engine is a logical component of the Federation Service that examines the set of incoming claims presented by a user, and will then, depending on the logic in each rule, produce an output set of claims.

How to create a claim rule

Claim rules are created separately for each federated trust relationship within the Federation Service and aren't shared across multiple trusts. You can either create a rule from a claim rule template, start from scratch by authoring the rule using the claim rule language or use Windows PowerShell to customize a rule.

Understanding the components of the claim rule language

The claim rule language consists of the following components, separated by the “ =>” operator:

  • A condition: Used to check input claims and determine whether the issuance statement of the rule should be executed. It represents a logical expression that must be evaluated to true to execute the rule body part.

  • An issuance statement.

Example:

c:[type == "Name", value == "domain user"] => issue(type = "Role", value = "employee");

This claim has the following:

  • Condition - c:[type == "Name", value == "domain user"] - evaluates the input claim of whether the windows account name is a domain user.
  • Issuance - issue(type = "Role", value = "employee") - if the condition is true, adds a new claim to the input claim with the role of employee.

For more information on claims and the syntax, see The Role of the Claims Rule Language.

Claims rule editor

Syntax checking is performed by the claims rule editor once you have completed the claim and select OK. So if you have the incorrect syntax, then the editor will let you know.

Screenshot of the A D F S Management dialog box showing a message stating that the custom claim rule syntax is not valid.

Event logs

When looking trying to troubleshoot a claim using the logs the best approach is to look for claims output. You can look for 1000 and 1001 events in the event log.

Screenshot of the Event Properties dialog box showing the results of a 1000 event I D.

Creating a sample application

You can also create a sample application the echoes your claims. For example, you can use a sample application and create a relying party that has the same claim you are trying to troubleshoot and see if the app has any issues with that claim.

Screenshot of the sample application displayed in a browser.

A good sample web app is available here. This app echoes back the claims that it receives from the relying party. In order to use this, you need to edit the web.config app by:

  • Changing https://app1.contoso.com/sampapp to the URL that will be used for hosting the sample app.
  • Changing all instances of sts.contoso.com to point to your AD FS federation server.
  • Replacing the thumbprint with your thumbprint.
  • Replacing the decryptionKey and the validationKey with values that are appropriate for your scenario.

Screenshot of Visual Studio showing the web config file.

The following blog article has excellent, in-depth instructions, for setting this up.

Next Steps