2 * Copyright (c) 2014, 2017 Hewlett-Packard Development Company, L.P. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.aaa.shiro.tokenauthrealm.auth;
10 import java.io.Serializable;
12 import org.opendaylight.aaa.api.Authentication;
13 import org.opendaylight.aaa.api.Claim;
14 import org.opendaylight.aaa.shiro.tokenauthrealm.util.EqualUtil;
15 import org.opendaylight.aaa.shiro.tokenauthrealm.util.HashCodeUtil;
18 * A builder for the authentication context.
21 * The expiration DEFAULTS to 0.
25 public class AuthenticationBuilder {
27 private long expiration = 0L;
28 private final Claim claim;
30 public AuthenticationBuilder(Claim claim) {
34 public AuthenticationBuilder setExpiration(long expiration) {
35 this.expiration = expiration;
39 public Authentication build() {
40 return new ImmutableAuthentication(this);
43 private static final class ImmutableAuthentication implements Authentication, Serializable {
44 private static final long serialVersionUID = 4919078164955609987L;
45 private int hashCode = 0;
49 private ImmutableAuthentication(AuthenticationBuilder base) {
50 if (base.claim == null) {
51 throw new IllegalStateException("The Claim is null.");
53 claim = new ClaimBuilder(base.claim).build();
54 expiration = base.expiration;
56 if (base.expiration < 0) {
57 throw new IllegalStateException("The expiration is less than 0.");
62 public long expiration() {
67 public String clientId() {
68 return claim.clientId();
72 public String userId() {
73 return claim.userId();
77 public String user() {
82 public String domain() {
83 return claim.domain();
87 public Set<String> roles() {
92 public boolean equals(Object object) {
96 if (!(object instanceof Authentication)) {
99 Authentication authentication = (Authentication) object;
100 return EqualUtil.areEqual(expiration, authentication.expiration()) && EqualUtil
101 .areEqual(claim.roles(), authentication.roles()) && EqualUtil
102 .areEqual(claim.domain(), authentication.domain()) && EqualUtil
103 .areEqual(claim.userId(), authentication.userId()) && EqualUtil
104 .areEqual(claim.user(), authentication.user()) && EqualUtil
105 .areEqual(claim.clientId(), authentication.clientId());
109 public int hashCode() {
111 int result = HashCodeUtil.SEED;
112 result = HashCodeUtil.hash(result, expiration);
113 result = HashCodeUtil.hash(result, claim.hashCode());
120 public String toString() {
121 return "expiration:" + expiration + "," + claim.toString();