/*
* Copyright (C) 2005-2012 Alfresco Software Limited.
*
* This file is part of Alfresco
*
* Alfresco is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Alfresco is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Alfresco. If not, see
* AlfrescoSchema-MySQL-alf_-2334829.xml ** Where the database object prefix is substituted for parameter {0} and the random number * is produced by the File.createTempFile() method. The suffix .xml is always used. * * @author Matt Ward */ public class MultiFileDumper { private final String[] dbPrefixes; private final File directory; private final String fileNameTemplate; private final DbToXMLFactory dbToXMLFactory; private final static String fileNameSuffix = ".xml"; public final static String[] DEFAULT_PREFIXES = new String[] { "alf_", "avm_", "jbpm_", "act_" }; /** * Constructor with all available arguments. * * @param dbPrefixes * @param directory * @param fileNameTemplate * @param dbToXMLFactory */ public MultiFileDumper(String[] dbPrefixes, File directory, String fileNameTemplate, DbToXMLFactory dbToXMLFactory) { ParameterCheck.mandatory("dbPrefixes", dbPrefixes); ParameterCheck.mandatory("directory", directory); ParameterCheck.mandatory("fileNameTemplate", fileNameTemplate); ParameterCheck.mandatory("dbToXMLFactory", dbToXMLFactory); if (dbPrefixes.length == 0) { throw new IllegalArgumentException("At least one database object prefix is required."); } this.dbPrefixes = dbPrefixes; this.directory = directory; this.fileNameTemplate = fileNameTemplate; this.dbToXMLFactory = dbToXMLFactory; } /** * Construct a MultiFileDumper with the {@link MultiFileDumper#DEFAULT_PREFIXES}. * * @param directory * @param fileNameTemplate * @param dbToXMLFactory */ public MultiFileDumper(File directory, String fileNameTemplate, DbToXMLFactory dbToXMLFactory) { this(DEFAULT_PREFIXES, directory, fileNameTemplate, dbToXMLFactory); } public List