org.kuali.common.util.metainf.spring.RiceSqlConfig Maven / Gradle / Ivy
/**
* Copyright 2010-2014 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.metainf.spring;
import java.io.File;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.kuali.common.util.metainf.model.MetaInfContext;
import org.kuali.common.util.metainf.model.MetaInfResource;
import org.kuali.common.util.metainf.model.MetaInfResourceFilenameComparator;
import org.kuali.common.util.metainf.model.MetaInfResourceLocationComparator;
import org.kuali.common.util.metainf.service.MetaInfUtils;
import org.kuali.common.util.nullify.NullUtils;
import org.kuali.common.util.project.ProjectUtils;
import org.kuali.common.util.project.model.Build;
import org.kuali.common.util.project.model.Project;
import org.kuali.common.util.project.spring.AutowiredProjectConfig;
import org.kuali.common.util.spring.SpringUtils;
import org.kuali.common.util.spring.env.EnvironmentService;
import org.kuali.common.util.spring.service.SpringServiceConfig;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
/**
* TODO Should not be a class called {@code RiceSqlConfig} down here in kuali-util. Create a rice-util and move this there? Main issue preventing this from living in the rice-xml
* module itself is that it gets tricky having software used very early in the build lifecycle reside in the same project that makes use of it.
*/
@Configuration
@Import({ AutowiredProjectConfig.class, MetaInfExecutableConfig.class, SpringServiceConfig.class })
public class RiceSqlConfig implements MetaInfContextsConfig {
private static final boolean DEFAULT_GENERATE_RELATIVE_PATHS = true;
private static final String RELATIVE_KEY = MetaInfUtils.PROPERTY_PREFIX + ".sql.relative";
private static final String PREFIX = "sql";
private static final String DEFAULT_VENDORS = "mysql,oracle";
private static final String VENDORS_KEY = MetaInfUtils.PROPERTY_PREFIX + ".db.vendors";
private static final String IMPEX_ARTIFACT_ID = "rice-impex-master";
@Autowired
EnvironmentService env;
@Autowired
Project project;
@Autowired
Build build;
@Override
@Bean
public List metaInfContexts() {
List vendors = SpringUtils.getNoneSensitiveListFromCSV(env, VENDORS_KEY, DEFAULT_VENDORS);
List contexts = new ArrayList();
for (String vendor : vendors) {
for (MetaInfGroup group : MetaInfGroup.values()) {
MetaInfContext context = getMetaInfContext(group, vendor);
contexts.add(context);
}
}
return contexts;
}
protected MetaInfContext getMetaInfContext(MetaInfGroup group, String vendor) {
Map defaultIncludes = getDefaultIncludes(project, IMPEX_ARTIFACT_ID, vendor);
Map defaultExcludes = getDefaultExcludes(defaultIncludes);
boolean relativePaths = env.getBoolean(RELATIVE_KEY, DEFAULT_GENERATE_RELATIVE_PATHS);
File outputFile = MetaInfUtils.getOutputFile(project, build, vendor, group);
String includesKey = MetaInfConfigUtils.getIncludesKey(group, PREFIX) + "." + vendor;
String excludesKey = MetaInfConfigUtils.getExcludesKey(group, PREFIX) + "." + vendor;
List includes = SpringUtils.getNoneSensitiveListFromCSV(env, includesKey, defaultIncludes.get(group));
List excludes = SpringUtils.getNoneSensitiveListFromCSV(env, excludesKey, defaultExcludes.get(group));
File scanDir = build.getOutputDir();
String encoding = build.getEncoding();
Comparator comparator = getComparator(group);
return new MetaInfContext.Builder(outputFile, encoding, scanDir).comparator(comparator).includes(includes).excludes(excludes).relativePaths(relativePaths).build();
}
protected Comparator getComparator(MetaInfGroup group) {
if (MetaInfGroup.OTHER.equals(group)) {
// The upgrades folder for Rice has a nested directory structure - [server|client]:[bootstrap|demo|test].
// At the moment, the sorting of SQL located inside the "upgrades" folder for Rice ignores the directory structure and just sorts by filename.
// The idea is that the "initial-db" folder inside Rice will soon have a structure similar to the "upgrades" folder.
// This should enable "additive" dataset generation instead of "subtractive".
// Once the "initial-db" structure is in place, this specialized comparator should be removed.
// All SQL resources would then be sorted by the fully qualified location.
return new MetaInfResourceFilenameComparator();
} else {
return new MetaInfResourceLocationComparator();
}
}
protected Map getDefaultIncludes(Project project, String impexArtifactId, String vendor) {
String resourcePath = ProjectUtils.getResourcePath(project.getGroupId(), project.getArtifactId());
Map map = new HashMap();
map.put(MetaInfGroup.SCHEMA, resourcePath + "/initial-db/sql/" + vendor + "/" + impexArtifactId + ".sql");
map.put(MetaInfGroup.DATA, resourcePath + "/initial-db/sql/" + vendor + "/*.sql");
map.put(MetaInfGroup.CONSTRAINTS, resourcePath + "/initial-db/sql/" + vendor + "/" + impexArtifactId + "-constraints.sql");
map.put(MetaInfGroup.OTHER, resourcePath + "/upgrades/**/" + vendor + "/**/*.sql");
return map;
}
protected Map getDefaultExcludes(Map defaultIncludes) {
Map map = new HashMap();
// The schema includes is specific to one exact file, no need to exclude anything
map.put(MetaInfGroup.SCHEMA, NullUtils.NONE);
// Exclude the schema + constraints SQL
map.put(MetaInfGroup.DATA, defaultIncludes.get(MetaInfGroup.SCHEMA) + "," + defaultIncludes.get(MetaInfGroup.CONSTRAINTS));
// The constraint includes is specific to one exact file, no need to exclude anything
map.put(MetaInfGroup.CONSTRAINTS, NullUtils.NONE);
// No need to exclude any of the "upgrades" SQL
map.put(MetaInfGroup.OTHER, NullUtils.NONE);
return map;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy