[keycloak-user] attributes are not persisted
Max Bruchmann
max.bruchmann at hotmail.com
Wed Aug 22 04:35:36 EDT 2018
Ok, do you think the "extending registration form" will work if users register via google, facebook etc...?
With the LOGIN directly after REGISTER
you mean I could try something like this:
onLogin:
String externalID = userModel.getFirstAttribute("foo");
if(externalID == null){
String externalID = createSomethingWithUserEmail(userModel.getEmail())
userModel.setSingleAttribute("foo", externalID)
}
You think the transaction state is a different which then really perists the data or is the runJobInTransaction better working and will find the user?
Max
Am 20.08.18 um 19:08 schrieb Marek Posolda:
Maybe it's better to rather extend registration form as described here: https://www.keycloak.org/docs/latest/server_development/index.html#modifying-extending-the-registration-form
Alternative is, to update user directly in the LOGIN event after REGISTER event, but not 100% sure this one will work. Also even if it works, it's more a workaround.
Marek
On 10/08/18 19:32, Max Bruchmann wrote:
Hmm unfortunatelly if I use
KeycloakModelUtils.runJobInTransaction(session.getKeycloakSessionFactory(), (session) -> {
UserModel user = getUserModel(session, userId, realmId);
...
The user is null :/
Max
Am 10.08.18 um 09:03 schrieb Marek Posolda:
I am not 100% sure, but it's possible that updating users in the events don't currently work. Reason is, that transaction might be already commited. The possible solution long term is to use pre/post events for this (which we don't yet support).
For the short term, it may be possible to manually trigger your own temporarily transaction (You can take a look at KeycloakModelUtils.runJobInTransaction method). Note that in the new transaction, you need to ensure to not use Hibernate entities from the "outer" transaction (EG. all the things like RealmModel, UserModel need to be look-up again through the Model API in the new transaction).
Marek
On 09/08/18 21:39, Max Bruchmann wrote:
Hi,
I have a custom EventListenerProvider that consumes Register and Login events.
On register it creates some external resource
...//on register
String externalID = createSomethingWithUserEmail(userModel.getEmail())
userModel.setSingleAttribute("foo", externalID)
...
On login I need to todo some additional calls with the already created id.
...// on login
String externalID = userModel.getFirstAttribute("foo");
doSomeUpdate(externalID, userModel.getFirstName(), userModel.getLastName())
...
Unfortunatelly the retrieved id via getFirstAttribute seems to be null.
Is there anything I need todo when modifying attributes so they are persisted?
Kind Regards,
Max
_______________________________________________
keycloak-user mailing list
keycloak-user at lists.jboss.org<mailto:keycloak-user at lists.jboss.org>
https://lists.jboss.org/mailman/listinfo/keycloak-user
More information about the keycloak-user
mailing list