package com.intuit.tank.project;
/*
* #%L
* Intuit Tank data model
* %%
* Copyright (C) 2011 - 2015 Intuit Inc.
* %%
* 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
* #L%
*/
import java.util.HashSet;
import java.util.Set;
import java.util.UUID;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import javax.persistence.Table;
import org.apache.commons.lang3.builder.EqualsBuilder;
import org.apache.commons.lang3.builder.HashCodeBuilder;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.hibernate.annotations.Index;
import org.hibernate.envers.Audited;
import org.hibernate.validator.constraints.Length;
import org.hibernate.validator.constraints.NotEmpty;
/**
*
* Project top level Object in data model. All objects are eventually traversable from their project.
*
* @author dangleton
*
*/
@Entity
@Table(name = "user")
@Audited
public class User extends BaseEntity {
private static final long serialVersionUID = 1L;
public static final String PROPERTY_NAME = "name";
public static final String PROPERTY_EMAIL = "email";
public static final String PROPERTY_TOKEN = "apiToken";
@Column(name = "name", unique = true, nullable = false)
@Index(name = "IDX_USER_NAME")
@NotEmpty
@Length(max = 255)
private String name;
@Column(name = "email", nullable = false)
@Index(name = "IDX_USER_EMAIL")
@NotEmpty
@Length(max = 255)
private String email;
@Column(name = "password", nullable = false)
private String password;
@Column(name = "token")
@Index(name = "IDX_USER_TOKEN")
private String apiToken;
@ManyToMany(cascade = { CascadeType.PERSIST, CascadeType.MERGE }, fetch = FetchType.EAGER)
@JoinTable(joinColumns = @JoinColumn(name = "group_id"),
inverseJoinColumns = @JoinColumn(name = "user_id"))
private Set<Group> groups = new HashSet<Group>();
public User() {
}
/**
* @param groups
* the groups to set
*/
public void setGroups(Set<Group> groups) {
this.groups = groups;
}
public void addGroup(Group group) {
this.groups.add(group);
}
/**
* @return the name
*/
public String getName() {
return name;
}
/**
* @param name
* the name to set
*/
public void setName(String name) {
this.name = name;
}
/**
* @return the email
*/
public String getEmail() {
return email;
}
/**
* @return the apiToken
*/
public String getApiToken() {
return apiToken;
}
/**
* @param apiToken
* the apiToken to set
*/
public void generateApiToken() {
this.apiToken = UUID.randomUUID().toString();
}
/**
* @param email
* the email to set
*/
public void setEmail(String email) {
this.email = email;
}
/**
* @return the password
*/
public String getPassword() {
return password;
}
/**
* @param password
* the password to set
*/
public void setPassword(String password) {
this.password = password;
}
/**
* @return the groups
*/
public Set<Group> getGroups() {
return groups;
}
/**
* @{inheritDoc
*/
@Override
public String toString() {
return new ToStringBuilder(this).append("id", getId()).append("name", name)
.toString();
}
/**
* @{inheritDoc
*/
@Override
public boolean equals(Object obj) {
if (!(obj instanceof User)) {
return false;
}
User o = (User) obj;
return new EqualsBuilder().append(o.getId(), getId()).isEquals();
}
/**
* @{inheritDoc
*/
@Override
public int hashCode() {
return new HashCodeBuilder(29, 45).append(getId()).toHashCode();
}
}