X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;f=security%2Fusermgt%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fsecurity%2Fauthorization%2FGroupUserCondition.java;fp=security%2Fusermgt%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fsecurity%2Fauthorization%2FGroupUserCondition.java;h=f50c3d120bfb38468cbe115c44b23928f72b4052;hb=9449ea0f360f6e9c14057db57f3ee0bfba947ab4;hp=0000000000000000000000000000000000000000;hpb=e8b988e92306a4aea2f047af1b48588147288831;p=utils diff --git a/security/usermgt/src/main/java/org/wamblee/security/authorization/GroupUserCondition.java b/security/usermgt/src/main/java/org/wamblee/security/authorization/GroupUserCondition.java new file mode 100644 index 00000000..f50c3d12 --- /dev/null +++ b/security/usermgt/src/main/java/org/wamblee/security/authorization/GroupUserCondition.java @@ -0,0 +1,98 @@ +/* + * Copyright 2005-2010 the original author or authors. + * + * Licensed 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.wamblee.security.authorization; + + +import javax.persistence.Column; +import javax.persistence.DiscriminatorValue; +import javax.persistence.Entity; +import javax.persistence.Transient; + +import org.wamblee.security.authentication.UserAdministration; + + +/** + * Checks if a user against a specific group. + * + * @author Erik Brakkee + */ +@Entity +@DiscriminatorValue("GROUP") +public class GroupUserCondition extends AbstractUserCondition { + /** + * Group the user must be in. + */ + @Column(name = "GRP") + private String group; + + @Transient + private UserAdministration admin; + + /** + * Constructs the condition. + * + * @param aGroup + * Group the user must be in. + */ + public GroupUserCondition(String aGroup) { + group = aGroup; + } + + /** + * For OR mapping. + * + */ + protected GroupUserCondition() { + group = null; + } + + @Override + public void setUserAdmin(UserAdministration aAdmin) { + admin = aAdmin; + } + + @Override + public boolean matches(String aUser) { + return admin.isInGroup(aUser, group); + } + + /** + * + * @return Returns the group. + */ + protected String getGroup() { + return group; + } + + /** + * + * @param aGroup + * The group to set. + */ + protected void setGroup(String aGroup) { + group = aGroup; + } + + /* + * (non-Javadoc) + * + * @see java.lang.Object#toString() + */ + @Override + public String toString() { + return "GroupUserCondition(group=" + group + ")"; + } +}