org.opendaylight.aaa.tokenauthrealm.auth.ClaimBuilder Maven / Gradle / Ivy
/*
* Copyright (c) 2014, 2017 Hewlett-Packard Development Company, L.P. and others. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
package org.opendaylight.aaa.tokenauthrealm.auth;
import com.google.common.base.Strings;
import com.google.common.collect.ImmutableSet;
import java.io.Serializable;
import java.util.LinkedHashSet;
import java.util.Objects;
import java.util.Set;
import org.opendaylight.aaa.api.Claim;
/**
* Builder for a {@link Claim}. The userId, user, and roles information is
* mandatory.
*
* @author liemmn
*/
public class ClaimBuilder {
private String userId = "";
private String user = "";
private final Set roles = new LinkedHashSet<>();
private String clientId = "";
private String domain = "";
public ClaimBuilder() {
}
public ClaimBuilder(final Claim claim) {
clientId = claim.clientId();
userId = claim.userId();
user = claim.user();
domain = claim.domain();
roles.addAll(claim.roles());
}
public ClaimBuilder setClientId(final String clientId) {
this.clientId = Strings.nullToEmpty(clientId).trim();
return this;
}
public ClaimBuilder setUserId(final String userId) {
this.userId = Strings.nullToEmpty(userId).trim();
return this;
}
public ClaimBuilder setUser(final String userName) {
user = Strings.nullToEmpty(userName).trim();
return this;
}
public ClaimBuilder setDomain(final String domain) {
this.domain = Strings.nullToEmpty(domain).trim();
return this;
}
public ClaimBuilder addRoles(final Set theRoles) {
for (String role : theRoles) {
addRole(role);
}
return this;
}
public ClaimBuilder addRole(final String role) {
roles.add(Strings.nullToEmpty(role).trim());
return this;
}
public Claim build() {
return new ImmutableClaim(this);
}
protected static class ImmutableClaim implements Claim, Serializable {
private static final long serialVersionUID = -8115027645190209129L;
private int hashCode = 0;
protected String clientId;
protected String userId;
protected String user;
protected String domain;
protected ImmutableSet roles;
protected ImmutableClaim(final ClaimBuilder base) {
clientId = base.clientId;
userId = base.userId;
user = base.user;
domain = base.domain;
roles = ImmutableSet.builder().addAll(base.roles).build();
if (userId.isEmpty() || user.isEmpty() || roles.isEmpty() || roles.contains("")) {
throw new IllegalStateException(
"The Claim is missing one or more of the required fields.");
}
}
@Override
public String clientId() {
return clientId;
}
@Override
public String userId() {
return userId;
}
@Override
public String user() {
return user;
}
@Override
public String domain() {
return domain;
}
@Override
public Set roles() {
return roles;
}
@Override
public boolean equals(final Object obj) {
return this == obj || obj instanceof Claim other
&& Objects.equals(roles, other.roles())
&& Objects.equals(domain, other.domain())
&& Objects.equals(userId, other.userId())
&& Objects.equals(user, other.user())
&& Objects.equals(clientId, other.clientId());
}
@Override
public int hashCode() {
if (hashCode == 0) {
hashCode = Objects.hash(clientId, userId, user, domain, roles);
}
return hashCode;
}
@Override
public String toString() {
return "clientId:" + clientId + "," + "userId:" + userId + "," + "userName:" + user
+ "," + "domain:" + domain + "," + "roles:" + roles;
}
}
}