Use of the eduPersonPrincipleName attribute should be reconsidered and possibly be phased out and replaced with the subject-id attribute from the OASIS SAML 2.0 SubjectID Attributes Profile.


A scoped identifier for a person. It should be represented in the form "user@scope" where "user" is a name-based identifier for the person and where the "scope" portion MUST be the administrative domain of the identity system where the identifier was created and assigned. – eduPerson

This is a globally unique identifier that looks like an email address but does not have to be. (It can be a valid email address, if you want, but noone recieving the value as an eduPersonPrincipalName attribute should try to send email there.)

Many applications expect an identifier that's suitable to being shown in the interface once logged-in. I.e., there's an expectation that an identifier is (among other things):

Most applications also seem to expect that such identifiers never change, which combined with the other requirements (globally unique, not overly long, not ugly, known/recognizable to the subject) makes this impossible to fulfill at most academic institutions. I.e., you can't win and no one attribute can solve all the requirements people throw at it.

 Practically speaking there are only two reasonable ways to generate eduPersonPrincipalName values:

  1. from the login name (from whatever local attribute, e.g. uid, cn, sAMAccountName, etc.) by appending the scope of the IDP (e.g. @example.ac.at), or
  2. by re-using the email address as eduPersonPrincipalName attribute.

The first variant (login name + scope) has the disadvantage of exposing part of the login credentials – though the login name/userid shouldn't generally be considered secret as there usually are many ways to discover it. At least it's guaranteed to exist and can be assumed to be well-known to the subject (as it has to be entered for authentication purposes), at least in its "unscoped" form.
The second variant (re-using email address values) has the problem that this only works if you're issuing email addresses in your domain (IDP scope) for all subjects who should also have an eduPersonPrincipalName (which is all your population, basically). This is required because SAML Service Providers check the scope (domain part) of eduPersonPrincipalName attibute values against the published (i.e., allowed) scopes of IDPs (column "scope") in order to protect themselfs from IDP impersonation (i.e., one IDP asserting vales from from another IDP). So if your IDM system hands over external email addresses to your SAML IDP (e.g. @gmx.net, @gmail.com, etc.) you cannot re-use email addresses as eduPersonPrincipalName attributes (at least not for that part of the population that only has external email addresses).

Of course all variants here have the issue that email addresses (and sometimes even login names) are occasionally desired to change, e.g. when people change their names after marriage/divorce/religious convertion and wish for their email address (and/or login name) to reflect those changes. And sometimes the "old" (used before the change) email address/identifier might even be re-assigned to another person (the worst case), maybe after a dormancy period of a few years. So applications relying on eduPersonPrincipalName (or any identifier that doesn't prohibit reassignment itself) will need to be prepared to handle such changes.

eduPersonPrincipalName Alternatives

For application integrators the potential alternatives to relying on eduPersonPrincipalName in the Higher Education and Research sector basically are:

Examples: