What is the relationship between the OpenID sreg and ax extensions? How does a relying party know which one to request, or both?
OpenID Simple Registration (sreg) vs. Attribute Exchange (ax)
2.7k Views Asked by joeforker At
1
There are 1 best solutions below
Related Questions in OPENID
- Is it possible to get a list of all the pages where I authenticated with my Google OpenID
- integrate login to my sites with OpenId or OAuth
- Use Bearer Token Authentication for API and OpenId authentication for MVC on the same application project
- PHP - Steam API Web Connect OpenID --> No redirect
- Identity Server OAuth Resource Owner Password Grant always returns invalid_client
- Validate an Access Token at the Resource Server and Respond Accordingly
- owin: Catch SecurityTokenExpiredException exception
- What exactly will happen to Google OpenId Connect to OpenID 2.0 mapping on Jan 1, 2017?
- Implementing Steam OpenID for iOS
- OAuth vs OpenID: confused about when to use one of these and why
- wso2carbon programmatically/configuration always consent
- Use identityserver3 as OpenID provider for other websites
- AuthenticationValidated event in OpenIdConnectEvents doesn't exist in AspNetCore 1.1 so where should I add claims client side
- Oidc-client with IdentityServer3 - Angular2, how to logout and login properly
- Google OpenID Connect: How to verify id_token?
Related Questions in SREG
- OpenID Simple Registration (sreg) vs. Attribute Exchange (ax)
- JanRain PHP OpenID: How to check if a provider supports AX programmatically?
- JanRain OpenID in PHP SREG?
- getting SREG data using Zend_Auth and OpenID
- OpenID SReg Optional vs Required
- Is there anywhere a reference of all OpenID providers that support SREG or AX?
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
sreg was written as the Simplest Thing that could Possibly Work, and has a very limited set of fields available. But since that includes
nickname,email, andfullname, that's often all you need.Attribute Exchange is much more extensible and featureful, although I suspect in practice features like the
update_urland store request have not been widely implemented.As for knowing which to request: In theory, which extensions a provider supports is documented in the XRDS document available during the discovery phase, as noted in the Extensions section of the spec. If you're using python-openid (or perhaps one of the other libraries at OpenID Enabled), you could query for that via something like
Unfortunately, OpenID identifier delegation makes that pretty unreliable. The user may be using the HTML-based discovery method, which doesn't advertise extensions at all, may have an XRDS that doesn't include the same extension information as the provider does, or an XRDS that was once accurate but is now out of date.
In addition, even if you do get an XRDS that advertises the AX extension, as far as I know it doesn't tell you which attributes the provider supports (i.e. which AX schema).
The most practical approach is probably to request lots of stuff, and if you get some stuff back, you can use it.