Keycloak добавляет атрибуты пользователю через API и ошибку 409
Я пытаюсь добавить атрибут к существующему пользователю Keycloak:10.0.1.
@Override
public void addAttribute(String userId, String value) throws UserDoesNotExistException {
log.info("Trying add attribute to user: " + userId);
Keycloak keycloak = getClient();
RealmResource realmResource = keycloak.realm(configuration.getKeycloakRealm());
final UserResource userResource = realmResource.users().get(userId);
final UserRepresentation user = userResource.toRepresentation();
if (user.getAttributes() == null) {
user.setAttributes(new HashMap<>());
}
user.getAttributes().put(Const.SOME_ATTRIBUTE, Collections.singletonList(value));
userResource.update(user);
log.info("Attribute to user: " + userId + " added successfully");
}
и я получаю ошибку HTTP-409:
Caused by: javax.ws.rs.ClientErrorException: HTTP 409 Conflict
at org.jboss.resteasy.resteasy-jaxrs@3.6.3.Final//org.jboss.resteasy.client.jaxrs.internal.ClientInvocation.handleErrorStatus(ClientInvocation.java:237)
at org.jboss.resteasy.resteasy-jaxrs@3.6.3.Final//org.jboss.resteasy.client.jaxrs.internal.proxy.extractors.DefaultEntityExtractorFactory$3.extractEntity(DefaultEntityExtractorFactory.java:50)
at org.jboss.resteasy.resteasy-jaxrs@3.6.3.Final//org.jboss.resteasy.client.jaxrs.internal.proxy.ClientInvoker.invokeSync(ClientInvoker.java:150)
at org.jboss.resteasy.resteasy-jaxrs@3.6.3.Final//org.jboss.resteasy.client.jaxrs.internal.proxy.ClientInvoker.invoke(ClientInvoker.java:112)
at org.jboss.resteasy.resteasy-jaxrs@3.6.3.Final//org.jboss.resteasy.client.jaxrs.internal.proxy.ClientProxy.invoke(ClientProxy.java:76)
1 ответ
РЕШЕНИЕ: значение атрибута было слишком длинным. Вам нужно изменить размер в базе данных keycloak.
ALTER TABLE атрибут_пользователя ALTER COLUMN значение TYPE TEXT;
Тип по умолчанию - VARCHAR(255)