8b6eee9433bdabb29a463b55ab81a22c7ef422dc
[utils] / security / impl / src / main / java / org / wamblee / security / authorization / UserCondition.java
1 /*
2  * Copyright 2005-2010 the original author or authors.
3  * 
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  * 
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  * 
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */ 
16 package org.wamblee.security.authorization;
17
18 import javax.persistence.DiscriminatorColumn;
19 import javax.persistence.Entity;
20 import javax.persistence.GeneratedValue;
21 import javax.persistence.GenerationType;
22 import javax.persistence.Id;
23 import javax.persistence.Inheritance;
24 import javax.persistence.InheritanceType;
25 import javax.persistence.Table;
26 import javax.persistence.Version;
27
28 import org.wamblee.usermgt.User;
29
30 /**
31  * Condition used to match a user against a specified set of users.
32  * 
33  * @author Erik Brakkee
34  */
35 @Entity
36 @Table(name = "SEC_USER_CONDITION")
37 @Inheritance(strategy = InheritanceType.SINGLE_TABLE)
38 @DiscriminatorColumn(name = "TYPE")
39 public abstract class UserCondition {
40     
41     @Id
42     @GeneratedValue(strategy = GenerationType.AUTO)
43     private Long primaryKey;
44
45     @Version
46     private int version;
47     
48     public UserCondition() { 
49         // Empty.
50     }
51     
52     public UserCondition(UserCondition aCondition) { 
53         primaryKey = aCondition.primaryKey;
54         version = aCondition.version;
55     }
56     
57     /**
58      * Determines if the condition matches.
59      * 
60      * @param aUser
61      *            user to check.
62      * 
63      * @return True if the condition matches, false otherwise.
64      */
65     public abstract boolean matches(User aUser);
66 }