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

org.kuali.common.util.spring.ProjectPropertiesLoaderFactoryBean Maven / Gradle / Ivy

/**
 * Copyright 2010-2013 The Kuali Foundation
 *
 * Licensed under the Educational Community 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.opensource.org/licenses/ecl2.php
 *
 * 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.kuali.common.util.spring;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Properties;

import org.kuali.common.util.Assert;
import org.kuali.common.util.FormatUtils;
import org.kuali.common.util.PropertyUtils;
import org.kuali.common.util.property.ProjectProperties;
import org.kuali.common.util.property.ProjectPropertiesComparator;
import org.kuali.common.util.property.PropertiesContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.FactoryBean;
import org.springframework.util.CollectionUtils;

/**
 * 
 */
public class ProjectPropertiesLoaderFactoryBean implements FactoryBean {

	private static final Logger logger = LoggerFactory.getLogger(ProjectPropertiesLoaderFactoryBean.class);

	List locations;
	boolean singleton = true;
	ProjectPropertiesComparator comparator;

	@Override
	public Properties getObject() {
		Assert.isFalse(CollectionUtils.isEmpty(locations), "locations is empty");
		long start = System.currentTimeMillis();
		List pps = new ArrayList();
		// Extract any ProjectProperties beans anywhere in the context
		for (String location : locations) {
			Map beans = SpringUtils.getAllBeans(location, ProjectProperties.class);
			logger.info("Located {} sets of project properties", beans.size());

			List list = new ArrayList();
			// Add them to a list
			for (ProjectProperties bean : beans.values()) {
				list.add(bean);
			}
			// Sort them by sequence (only relevant if there is more than one which there typically is not)
			pps.addAll(list);
		}

		// Cycle through the list we have adding in properties as we go
		Properties properties = new Properties();
		for (ProjectProperties pp : pps) {
			PropertiesContext ctx = pp.getPropertiesContext();
			Properties combined = PropertyUtils.combine(properties, ctx.getProperties());
			ctx.setProperties(combined);
			Properties loaded = PropertyUtils.load(ctx);
			properties.putAll(loaded);
		}
		String elapsed = FormatUtils.getTime(System.currentTimeMillis() - start);
		logger.info("Loaded {} properties.  Total time: {}", properties.size(), elapsed);
		return properties;
	}

	@Override
	public Class getObjectType() {
		return Properties.class;
	}

	@Override
	public boolean isSingleton() {
		return singleton;
	}

	public void setSingleton(boolean singleton) {
		this.singleton = singleton;
	}

	public List getLocations() {
		return locations;
	}

	public void setLocations(List locations) {
		this.locations = locations;
	}

	public ProjectPropertiesComparator getComparator() {
		return comparator;
	}

	public void setComparator(ProjectPropertiesComparator comparator) {
		this.comparator = comparator;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy