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
- My openID Authentication return 'You must have either https wrappers or curl enabled.'
- How to migrate from Azure Static Web Apps to Azure App Service?
- angular oauth 2 oidc doesn't work with github idp
- How can I validate users with state (or nonce) when using OpenID with Steam
- Authenticate to two or more Keycloak confidential clients via openid-connect
- My web application won't return JSON from the server, but the url in a browser does
- Steam OAuth 2 Login in Vaadin Application
- How to implement account linking in Blazor Web App?
- Automatic Login from 3rd-Party OneLogin Apps to My App
- How to enable OpenID Connect in Dataverse
- Additional scopes for OAuth2 LinkedIn Sing In product
- Unable to Access Protected Endpoints in Azure Web App Using OAuth 2.0 Client Credentials Grant in Postman
- integration openiddict identityServer .net core 7 with client .net framework 4.8
- Codeigniter OpenID ERR_SSL_PROTOCOL_ERROR
- ASP.NET Core 8 using open id failed to authenticate the Cookie scheme
Related Questions in SREG
- OpenID SReg Optional vs Required
- getting SREG data using Zend_Auth and OpenID
- Is there anywhere a reference of all OpenID providers that support SREG or AX?
- JanRain PHP OpenID: How to check if a provider supports AX programmatically?
- JanRain OpenID in PHP SREG?
- OpenID Simple Registration (sreg) vs. Attribute Exchange (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 # Hahtags
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.