All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.wicket.spring.FieldBeansCollector Maven / Gradle / Ivy

Go to download

Integration project to use Spring injection in your Wicket applications. See the wicket-spring-examples for integration patterns.

The newest version!
/*
 * 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.wicket.spring;

import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;

import org.springframework.core.ResolvableType;

/**
 * Convenience class to extract information about the type and generics of a field to inject.
 * The field is a List, a Map or a Set and the generic type of its elements is extracted as well
 * 
 * @author Tobias Soloschenko
 * @author Andrea Del Bene
 */
public class FieldBeansCollector
{
	private final FieldType fieldType;
	
	private final Map beansToInjectMap;
	
	private final Collection beansToInjectColl;
	
	public enum FieldType
	{
		LIST, SET, MAP, NONE
	}

	public FieldBeansCollector(final ResolvableType fieldResolvableType)
	{
		Class clazz = fieldResolvableType.resolve();
		
		// The required code starts here which replaces
		if (clazz == Map.class)
		{
			fieldType = FieldType.MAP;
			// the getGeneric has to be called with 1 because the map contains the typified
			// information in the value generic
			beansToInjectColl = null;
			beansToInjectMap = new HashMap<>();
		}
		else if (clazz == Set.class)
		{
			fieldType = FieldType.SET;
			beansToInjectColl = new HashSet<>();
			beansToInjectMap = null;
		}
		else if (clazz == List.class)
		{
			fieldType = FieldType.LIST;
			beansToInjectColl = new ArrayList<>();
			beansToInjectMap = null;
		}
		else
		{
			fieldType = FieldType.NONE;
			beansToInjectColl = null;
			beansToInjectMap = null;
		}
	}
	
	/**
	 * Returns an instance containing all the beans collected for the field and
	 * compatible with the type of the field.
	 * 
	 * @return the instance to inject into the field.
	 */
	public Object getBeansToInject()
	{
		if (beansToInjectMap != null && beansToInjectMap.size() > 0)
		{
			return beansToInjectMap;
		}
		
		if (beansToInjectColl != null && beansToInjectColl.size() > 0)
		{
			return beansToInjectColl;
		}
		
		return null;
	}
	
	/**
	 * Adds compatible bean to the field. This means that the field type is Map, a List or a Set
	 * and that the given bean is compatible with its elements type.
	 * 
	 * @param beanName
	 * 				the name of the bean to inject
	 * @param bean
	 * 				the bean to inject
	 */
	public void addBean(String beanName, Object bean)
	{
		switch (fieldType)
		{
			case LIST : 
			case SET :
				beansToInjectColl.add(bean);
				break;
			case MAP :
				beansToInjectMap.put(beanName, bean);
				break;
			default :
				break;
		}
	}
	
	public FieldType getFieldType()
	{
		return fieldType;
	}
}