com.brihaspathee.zeus.domain.security.User Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tp-service Show documentation
Show all versions of tp-service Show documentation
Service that contains all Trading Partner Information
The newest version!
package com.brihaspathee.zeus.domain.security;
import jakarta.persistence.CascadeType;
import jakarta.persistence.Table;
import lombok.*;
import org.hibernate.annotations.*;
import org.springframework.security.core.CredentialsContainer;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.authority.SimpleGrantedAuthority;
import org.springframework.security.core.userdetails.UserDetails;
import jakarta.persistence.*;
import java.sql.Types;
import java.time.LocalDateTime;
import java.util.Collection;
import java.util.Objects;
import java.util.Set;
import java.util.UUID;
import java.util.stream.Collectors;
/**
* Created in Intellij IDEA
* User: Balaji Varadharajan
* Date: 21, January 2022
* Time: 9:09 AM
* Project: Zeus
* Package Name: com.zeus.domain.entity
* To change this template use File | Settings | File and Code Template
*/
@Getter
@Setter
@Builder
@AllArgsConstructor
@NoArgsConstructor
@Entity
@Table(name = "SECURITY_USER")
public class User implements UserDetails, CredentialsContainer {
@Id
@GeneratedValue(generator = "UUID")
@JdbcTypeCode(Types.LONGVARCHAR)
@GenericGenerator(name="UUID", strategy = "org.hibernate.id.UUIDGenerator")
@Column(name = "user_id", length = 36, columnDefinition = "varchar", updatable = false, nullable = false)
private UUID userId;
@Column(name = "username", nullable = false, length = 100)
private String username;
@Column(name = "password", nullable = false, length = 200)
private String password;
@Column(name = "account_not_expired", nullable = false)
@Builder.Default
private boolean accountNotExpired = true;
@Column(name = "account_not_locked", nullable = false)
@Builder.Default
private boolean accountNotLocked = true;
@Column(name = "credentials_not_expired", nullable = false)
@Builder.Default
private boolean credentialsNotExpired = true;
@Column(name = "enabled", nullable = false)
@Builder.Default
private boolean enabled = true;
@Singular
@ManyToMany(cascade = {CascadeType.MERGE}, fetch = FetchType.EAGER)
@JoinTable(name = "USER_ROLE",
joinColumns = {@JoinColumn(name = "USER_ID")},
inverseJoinColumns = {@JoinColumn(name = "ROLE_ID")})
private Set roles;
@CreationTimestamp
@Column(name = "created_date", nullable = false)
private LocalDateTime createdDate;
@UpdateTimestamp
@Column(name = "updated_date", nullable = false)
private LocalDateTime updatedDate;
@Override
public void eraseCredentials() {
this.password = null;
}
@Override
public Collection extends GrantedAuthority> getAuthorities() {
return this.roles.stream()
.map(Role::getAuthorities)
.flatMap(Set :: stream)
.map(authority -> {
return new SimpleGrantedAuthority(authority.getPermission());
}).collect(Collectors.toSet());
}
@Override
public String getPassword() {
return this.password;
}
@Override
public String getUsername() {
return this.username;
}
@Override
public boolean isAccountNonExpired() {
return this.accountNotExpired;
}
@Override
public boolean isAccountNonLocked() {
return this.accountNotLocked;
}
@Override
public boolean isCredentialsNonExpired() {
return this.credentialsNotExpired;
}
@Override
public boolean isEnabled() {
return this.enabled;
}
@Override
public String toString() {
return "User{" +
"userId=" + userId +
", username='" + username + '\'' +
", password='" + password + '\'' +
", accountNotExpired=" + accountNotExpired +
", accountNotLocked=" + accountNotLocked +
", credentialsNotExpired=" + credentialsNotExpired +
", enabled=" + enabled +
'}';
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
User user = (User) o;
return userId.equals(user.userId);
}
@Override
public int hashCode() {
return Objects.hash(userId);
}
}