/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you 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.apache.shiro.samples.sprhib.model; import org.hibernate.annotations.Cache; import org.hibernate.annotations.CacheConcurrencyStrategy; import org.hibernate.annotations.Index; import javax.persistence.*; import java.util.HashSet; import java.util.Set; /** * Simple class that represents any User domain entity in any application. * * <p>Because this class performs its own Realm and Permission checks, and these can happen frequently enough in a * production application, it is highly recommended that the internal User {@link #getRoles} collection be cached * in a 2nd-level cache when using JPA and/or Hibernate. The hibernate xml configuration for this sample application * does in fact do this for your reference (see User.hbm.xml - the 'roles' declaration).</p> */ @Entity @Table(name="users") @Cache(usage= CacheConcurrencyStrategy.READ_WRITE) public class User { private Long id; private String username; private String email; private String password; private Set<Role> roles = new HashSet<Role>(); @Id @GeneratedValue public Long getId() { return id; } public void setId(Long id) { this.id = id; } /** * Returns the username associated with this user account; * * @return the username associated with this user account; */ @Basic(optional=false) @Column(length=100) @Index(name="idx_users_username") public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } @Basic(optional=false) @Index(name="idx_users_email") public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } /** * Returns the password for this user. * * @return this user's password */ @Basic(optional=false) @Column(length=255) public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } @ManyToMany @JoinTable(name="users_roles") @Cache(usage=CacheConcurrencyStrategy.READ_WRITE) public Set<Role> getRoles() { return roles; } public void setRoles(Set<Role> roles) { this.roles = roles; } }