Java tutorial
/* * (c) Kitodo. Key to digital objects e. V. <contact@kitodo.org> * * This file is part of the Kitodo project. * * It is licensed under GNU General Public License version 3 or later. * * For the full copyright and license information, please read the * GPL3-License.txt file that was distributed with this source code. */ package de.sub.goobi.metadaten.copier; import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Map; import org.apache.commons.configuration.ConfigurationException; /** * The abstract class DataCopyrule defines method signatures to implement a rule * which may later be used to modify metadata depending on various conditions, * and provides a factory method to create the matching metadata copy rule * implementation from a given command string. * * @author Matthias Ronge <matthias.ronge@zeutschel.de> */ public abstract class DataCopyrule { /** * The final Map AVAILABLE_RULES maps the operators of the available * metadata copyrules to their respective classes. If more metadata * copyrules are to be added to this implementation, they will have to be * listed named here. */ private static final Map<String, Class<? extends DataCopyrule>> AVAILABLE_RULES = new HashMap<String, Class<? extends DataCopyrule>>( 4) { private static final long serialVersionUID = 1L; { put(ComposeFormattedRule.OPERATOR, ComposeFormattedRule.class); put(CopyIfMetadataIsAbsentRule.OPERATOR, CopyIfMetadataIsAbsentRule.class); put(OverwriteOrCreateRule.OPERATOR, OverwriteOrCreateRule.class); } }; /** * Factory method to create a class implementing the metadata copy rule * referenced by a given command string * * @param command * A space-separated string consisting of subject (aka. patiens), * operator (aka. agens) and (optional) objects (depending on * what objects the operator requires). * @return a class implementing the metadata copy rule referenced * @throws ConfigurationException * if the operator cannot be resolved or the number of arguments * doesnt match */ public static DataCopyrule createFor(String command) throws ConfigurationException { List<String> arguments = Arrays.asList(command.split("\\s+")); String operator; try { operator = arguments.get(1); } catch (IndexOutOfBoundsException e) { throw new ConfigurationException("Missing operator (second argument) in line: " + command); } Class<? extends DataCopyrule> ruleClass = AVAILABLE_RULES.get(operator); if (ruleClass == null) { throw new ConfigurationException("Unknown operator: " + operator); } DataCopyrule ruleImplementation; try { ruleImplementation = ruleClass.newInstance(); } catch (InstantiationException | IllegalAccessException e) { throw new RuntimeException(e.getMessage(), e); } ruleImplementation.setSubject(arguments.get(0)); if (ruleImplementation.getMaxObjects() > 0) { List<String> objects = arguments.subList(2, arguments.size()); if (objects.size() < ruleImplementation.getMinObjects()) { throw new ConfigurationException("Too few arguments in line: " + command); } if (objects.size() > ruleImplementation.getMaxObjects()) { throw new ConfigurationException("Too many arguments in line: " + command); } ruleImplementation.setObjects(objects); } return ruleImplementation; } /** * When called, the rule must be applied to the given fileformat. * * @param data * data to apply yourself on */ protected abstract void apply(CopierData data); /** * The function getMinObject must return the maximal number of objects * required by the rule to work as expected. If it returns 0, the * setObjects() method will not be called. * * @return the maximal number of objects required by the rule */ protected abstract int getMaxObjects(); /** * The function getMinObject must return the minimal number of objects * required by the rule to work as expected. * * @return the minimal number of objects required by the rule */ protected abstract int getMinObjects(); /** * The method setObjects() is called to pass the rule its objects. The list * passed is reliable to the restrictions defined by getMinObjects() and * getMaxObjects(). * * @param objects * a list of objects to be used by the rule * @throws ConfigurationException * may be thrown if one of the objects cannot be processed */ protected abstract void setObjects(List<String> objects) throws ConfigurationException; /** * The method setSubject() is called to pass the rule its subject. * * @param subject * a subject to be used by the rule * @throws ConfigurationException * may be thrown if the subject cannot be processed */ protected abstract void setSubject(String subject) throws ConfigurationException; }