/* * Copyright 2016 Red Hat, Inc. and/or its affiliates * and other contributors as indicated by the @author tags. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.keycloak.representations.idm; import com.fasterxml.jackson.databind.annotation.JsonDeserialize; import org.keycloak.json.StringListMapDeserializer; import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Set; /** * @author <a href="mailto:bill@burkecentral.com">Bill Burke</a> * @version $Revision: 1 $ */ public class UserRepresentation { protected String self; // link protected String id; protected String origin; protected Long createdTimestamp; protected String username; protected Boolean enabled; protected Boolean totp; protected Boolean emailVerified; protected String firstName; protected String lastName; protected String email; protected String federationLink; protected String serviceAccountClientId; // For rep, it points to clientId (not DB ID) @JsonDeserialize(using = StringListMapDeserializer.class) protected Map<String, List<String>> attributes; protected List<CredentialRepresentation> credentials; protected Set<String> disableableCredentialTypes; protected List<String> requiredActions; protected List<FederatedIdentityRepresentation> federatedIdentities; protected List<String> realmRoles; protected Map<String, List<String>> clientRoles; protected List<UserConsentRepresentation> clientConsents; @Deprecated protected Map<String, List<String>> applicationRoles; @Deprecated protected List<SocialLinkRepresentation> socialLinks; protected List<String> groups; public String getSelf() { return self; } public void setSelf(String self) { this.self = self; } public String getId() { return id; } public void setId(String id) { this.id = id; } public Long getCreatedTimestamp() { return createdTimestamp; } public void setCreatedTimestamp(Long createdTimestamp) { this.createdTimestamp = createdTimestamp; } public String getFirstName() { return firstName; } public void setFirstName(String firstName) { this.firstName = firstName; } public String getLastName() { return lastName; } public void setLastName(String lastName) { this.lastName = lastName; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public Boolean isEnabled() { return enabled; } public void setEnabled(Boolean enabled) { this.enabled = enabled; } @Deprecated public Boolean isTotp() { return totp; } @Deprecated public void setTotp(Boolean totp) { this.totp = totp; } public Boolean isEmailVerified() { return emailVerified; } public void setEmailVerified(Boolean emailVerified) { this.emailVerified = emailVerified; } public Map<String, List<String>> getAttributes() { return attributes; } public void setAttributes(Map<String, List<String>> attributes) { this.attributes = attributes; } public UserRepresentation singleAttribute(String name, String value) { if (this.attributes == null) attributes = new HashMap<>(); attributes.put(name, Arrays.asList(value)); return this; } public List<CredentialRepresentation> getCredentials() { return credentials; } public void setCredentials(List<CredentialRepresentation> credentials) { this.credentials = credentials; } public List<String> getRequiredActions() { return requiredActions; } public void setRequiredActions(List<String> requiredActions) { this.requiredActions = requiredActions; } public List<FederatedIdentityRepresentation> getFederatedIdentities() { return federatedIdentities; } public void setFederatedIdentities(List<FederatedIdentityRepresentation> federatedIdentities) { this.federatedIdentities = federatedIdentities; } public List<SocialLinkRepresentation> getSocialLinks() { return socialLinks; } public void setSocialLinks(List<SocialLinkRepresentation> socialLinks) { this.socialLinks = socialLinks; } public List<String> getRealmRoles() { return realmRoles; } public void setRealmRoles(List<String> realmRoles) { this.realmRoles = realmRoles; } public Map<String, List<String>> getClientRoles() { return clientRoles; } public void setClientRoles(Map<String, List<String>> clientRoles) { this.clientRoles = clientRoles; } public List<UserConsentRepresentation> getClientConsents() { return clientConsents; } public void setClientConsents(List<UserConsentRepresentation> clientConsents) { this.clientConsents = clientConsents; } @Deprecated public Map<String, List<String>> getApplicationRoles() { return applicationRoles; } public String getFederationLink() { return federationLink; } public void setFederationLink(String federationLink) { this.federationLink = federationLink; } public String getServiceAccountClientId() { return serviceAccountClientId; } public void setServiceAccountClientId(String serviceAccountClientId) { this.serviceAccountClientId = serviceAccountClientId; } public List<String> getGroups() { return groups; } public void setGroups(List<String> groups) { this.groups = groups; } /** * Returns id of UserStorageProvider that loaded this user * * @return NULL if user stored locally */ public String getOrigin() { return origin; } public void setOrigin(String origin) { this.origin = origin; } public Set<String> getDisableableCredentialTypes() { return disableableCredentialTypes; } public void setDisableableCredentialTypes(Set<String> disableableCredentialTypes) { this.disableableCredentialTypes = disableableCredentialTypes; } }