-
Notifications
You must be signed in to change notification settings - Fork 837
User profile params should return a map instead of an Array of maps #1323
Comments
Can you show an example of the result from the userinfo endpoint for the token server you're using? |
@brockallen the user info is in the first screenshot |
@brockallen noticed the user being stored in the session storage, session storage seems to be fine. Maybe related to this? |
It looks like the "params" is an object with the 2 props (role and the uri)? So I guess you're asking that it's just passed along as-is when merged into profile. It's possible that the id_token has "params" as well, so how would those look merged? |
Filtering out duplicates resulting in a single map instead of an array? |
Just checked it and the params are also in the JWT token. So is this expected behaviour that the type of the params key changes from dict to array? The id token params are not profile params, to calling |
For arbitrary object hierarchies, I would think this would be difficult. In the past my attitude was to just create an array and each object from the different sources get added in. |
Ah ok, so that explains why it's not just copied over directly. |
Just not sure if the idea of merging those params is correct. By creating an array of param object you're deviating from what the response provides. Also, parsing params from the JWT could be done in a separate method by simply moving that piece of to a method. Atm there is no way to distinct these params from each other. It's just an array of objects. |
But what if the two response objects are: It would not make sense to merge these. |
Hmm indeed the issue here is that there are 2 types of parameters being stored in a single property which from my point of view should not be the case. Parameters from the JWT are simply out of scope there and can be easily parsed in another way. The other parameter do actually have the intention to serve as profile parameters. At this moment all the profile parameters are merged into a single array, representing profile params, where a part of them are just params of your JWT. Think it's more a conceptual difference, maybe adding some extra documentation about this would clarify things for others |
Steps to Reproduce:
/me
call returns the user profile.const user = await userManager.getUser()
.Expected behaviour:
Calling
user.profile.params
would return a map of the extra user params.Actual result:
Calling
user.profile.params
returns the params as an array where each entry holds the exact same params as a map.Result of the
/me
call:Result of
userManager.getUser()
:The text was updated successfully, but these errors were encountered: