/*
* Copyright 2002-2006 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.openuap.cms.user.model;
import java.util.Collections;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import org.openuap.base.dao.hibernate.BaseObject;
/**
* <p>
* 带有扩展角色权限属性的对象
* </p>
*
* <p>
* $Id: RolePermissionWithFieldsObject.java 3939 2010-10-27 08:41:36Z orangeforjava $
* </p>
*
* @author Joseph
* @version 1.0
*/
public abstract class RolePermissionWithFieldsObject extends BaseObject {
/** */
protected Set<AbstractRolePermField> permissionFields;
protected Map<String, AbstractRolePermField> permissionFieldMap;
public Set<AbstractRolePermField> getPermissionFields() {
return permissionFields;
}
public void setPermissionFields(Set<AbstractRolePermField> permissionFields) {
this.permissionFields = permissionFields;
initFieldsMap();
}
// //
protected void initFieldsMap() {
if (permissionFields != null) {
permissionFieldMap = Collections
.synchronizedMap(new HashMap<String, AbstractRolePermField>());
Iterator<AbstractRolePermField> fieldIterator = permissionFields
.iterator();
while (fieldIterator.hasNext()) {
AbstractRolePermField permField = fieldIterator.next();
String fieldName = permField.getFieldName();
permissionFieldMap.put(fieldName, permField);
}
}
}
public AbstractRolePermField getField(String name) {
if (permissionFieldMap != null) {
return permissionFieldMap.get(name);
}
return null;
}
}