org.identityconnectors.framework.common.objects.AttributeInfoUtil Maven / Gradle / Ivy
The newest version!
/*
* ====================
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright 2008-2009 Sun Microsystems, Inc. All rights reserved.
*
* The contents of this file are subject to the terms of the Common Development
* and Distribution License("CDDL") (the "License"). You may not use this file
* except in compliance with the License.
*
* You can obtain a copy of the License at
* http://IdentityConnectors.dev.java.net/legal/license.txt
* See the License for the specific language governing permissions and limitations
* under the License.
*
* When distributing the Covered Code, include this CDDL Header Notice in each file
* and include the License file at identityconnectors/legal/license.txt.
* If applicable, add the following below this CDDL Header, with the fields
* enclosed by brackets [] replaced by your own identifying information:
* "Portions Copyrighted [year] [name of copyright owner]"
* ====================
*/
package org.identityconnectors.framework.common.objects;
import java.util.Collection;
import java.util.Map;
import java.util.Set;
import org.identityconnectors.common.Assertions;
import org.identityconnectors.common.CollectionUtil;
/**
* Utility methods to retrieve values from instances of {@link AttributeInfo}.
*/
public final class AttributeInfoUtil {
/**
* Transform a Collection
of {@link AttributeInfo} instances into
* a {@link Map}. The key to each element in the map is the name of
* an AttributeInfo
. The value of each element in the map is the
* AttributeInfo
instance with that name.
*
* @param attributes
* set of AttributeInfo to transform to a map.
* @return a map of string and AttributeInfo.
* @throws NullPointerException
* iff the parameter attributes is
* null.
*/
public static Map toMap(
Collection attributes) {
Map ret =
CollectionUtil.newCaseInsensitiveMap();
for (AttributeInfo attr : attributes) {
ret.put(attr.getName(), attr);
}
return ret;
}
/**
* Find the {@link AttributeInfo} of the given name in the {@link Set}.
*
* @param name
* {@link AttributeInfo}'s name to search for.
* @param attrs
* {@link Set} of AttributeInfo to search.
* @return {@link AttributeInfo} with the specified otherwise null
.
*/
public static AttributeInfo find(String name, Set attrs) {
Assertions.nullCheck(name, "name");
Set set = CollectionUtil.nullAsEmpty(attrs);
for (AttributeInfo attr : set) {
if (attr.is(name)) {
return attr;
}
}
return null;
}
}