Was trying to wrap my head around ADFS and Certificates today morning. Before I close all my links etc I thought I should make a note of them here. Whatever I say below is more or less based on these links (plus my understanding):
- ADFS Deep Dive – Certificate Planning
- How to update certificates for ADFS 3.0
- Understanding Certificates used by AD FS
- Certificate Requirements for Federation Servers
- (Update) Monitoring a Relying Party for Certificate changes
There are three types of certificates in ADFS.
The “Service communications” certificate is also referred to as “SSL certification” or “Server Authentication Certificate”. This is the certificate of the ADFS server/ service itself.
- If there’s a farm of ADFS servers, each must have the same certificate.
- We have the private key too for this certificate and can export it if this needs to be added to other ADFS servers in the farm.
- The Subject Name must contain the federation service name.
- This is the certificate that end users will encounter when they are redirected to the ADFS page to sign-on, so this must be a public CA issued certificate.
The “Token-signing” certificate is the crucial one.
- This is the certificate used by the ADFS server to sign SAML tokens.
- We have the private key too this certificate too but it cannot be exported. There’s no option in the GUI to export the private key. What we can do is export the public key/ certificate.
- ADFS servers in a farm can share the private key.
- If the certificate is from a public or enterprise CA, however, then the key can be exported (I think).
- The exported public certificate is usually loaded on the service provider (or relying party; basically the service where we can authenticate using our ADFS). They use it to verify our signature.
- The ADFS server signs tokens using this certificate (i.e. uses its private key to encrypt the token or a hash of the token – am not sure). The service provider using the ADFS server for authentication can verify the signature via the public certificate (i.e. decrypt the token or its hash using the public key and thus verify that it was signed by the ADFS server). This doesn’t provide any protection against anyone viewing the SAML tokens (as it can be decrypted with the public key) but does provide protection against any tampering (and verifies that the ADFS server has signed it).
- This can be a self-signed certificate. Or from enterprise or public CA.
- By default this certificate expires 1 year after the ADFS server was setup. A new certificate will be automatically generated 20 days prior to expiration. This new certificate will be promoted to primary 15 days prior to expiration.
- This auto-renewal can be disabled. PowerShell cmdlet
(Get-AdfsProperties).AutoCertificateRollover
tells you current setting. - The lifetime of the certificate can be changed to 10 years to avoid this yearly renewal.
- No need to worry about this on the WAP server.
- There can be multiple such certificates on an ADFS server. By default all certificates in the list are published, but only the primary one is used for signing.
The “Token-decrypting” certificate.
- This one’s a bit confusing to me. Mainly coz I haven’t used it in practice I think.
- This is the certificate used if a service provider wants to send us encrypted SAML tokens.
- Take note: 1) Sending us. 2) Not signed; encrypted.
- As with “Token-signing” we export the public part of this certificate, upload it with the 3rd party, and they can use that to encrypt and send us tokens. Since only we have the private key, no one can decrypt en route.
- This can be a self-signed certificate.
- Same renewal rules etc. as the “Token-signing” certificate.
- Important thing to remember (as it confused me until I got my head around it): This is not the certificate used by the service provider to send us signed SAML tokens. The certificate for that can be found in the signature tab of that 3rd party’s relaying party trust (see screenshot below).
- Another thing to take note of: A different certificate is used if we want to send encrypted info to the 3rd party. This is in the encryption tab of the same screenshot.
So – just to put it all in a table.
Clients accessing ADFS server | Service communications certificate |
ADFS server signing data and sending to 3rd party | Token-signing certificate |
3rd party encrypting data and sending ADFS server | Token-decrypting certificate |
3rd party signing data and sending ADFS server | Certificate in Signature tab of Trust |
ADFS server encrypting data and sending to 3rd party | Certificate in Encryption tab of Trust |
Update: Linking to a later post of mine on ADFS in general.
Update 2: Modification to the above table, using better terminology.
Clients accessing ADFS server | Service communications certificate |
We (Identity Provider STS) signing data and sending to a Relying Party STS | Token-signing certificate |
Relying Party STS encrypting data and sending us (Identity Provider STS) | Token-decrypting certificate |
[In a trust] Relying Party STS party signing data and sending us (Identity Provider STS) | Certificate in Signature tab of Trust |
[In a trust] We (Identity Provider STS) encrypting data and sending to Relying party STS | Certificate in Encryption tab of Trust |