⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 itemimport.java

📁 dspace 用j2ee架构的一个数字图书馆.开源程序
💻 JAVA
📖 第 1 页 / 共 3 页
字号:
/* * ItemImport.java * * Version: $Revision: 1.27 $ * * Date: $Date: 2005/11/16 21:40:51 $ * * Copyright (c) 2002-2005, Hewlett-Packard Company and Massachusetts * Institute of Technology.  All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * - Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * - Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * - Neither the name of the Hewlett-Packard Company nor the name of the * Massachusetts Institute of Technology nor the names of their * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH * DAMAGE. */package org.dspace.app.itemimport;import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.File;import java.io.FileInputStream;import java.io.FileReader;import java.io.FileWriter;import java.io.FilenameFilter;import java.io.IOException;import java.io.PrintWriter;import java.sql.SQLException;import java.util.ArrayList;import java.util.HashMap;import java.util.Iterator;import java.util.Map;import java.util.StringTokenizer;import javax.xml.parsers.DocumentBuilder;import javax.xml.parsers.DocumentBuilderFactory;import javax.xml.parsers.ParserConfigurationException;import javax.xml.transform.TransformerException;import org.apache.commons.cli.CommandLine;import org.apache.commons.cli.CommandLineParser;import org.apache.commons.cli.HelpFormatter;import org.apache.commons.cli.Options;import org.apache.commons.cli.PosixParser;import org.apache.xpath.XPathAPI;import org.dspace.authorize.AuthorizeException;import org.dspace.content.Bitstream;import org.dspace.content.BitstreamFormat;import org.dspace.content.Bundle;import org.dspace.content.Collection;import org.dspace.content.FormatIdentifier;import org.dspace.content.InstallItem;import org.dspace.content.Item;import org.dspace.content.MetadataSchema;import org.dspace.content.WorkspaceItem;import org.dspace.core.ConfigurationManager;import org.dspace.core.Constants;import org.dspace.core.Context;import org.dspace.eperson.EPerson;import org.dspace.handle.HandleManager;import org.dspace.workflow.WorkflowManager;import org.w3c.dom.Document;import org.w3c.dom.NamedNodeMap;import org.w3c.dom.Node;import org.w3c.dom.NodeList;import org.xml.sax.SAXException;/** * Import items into DSpace. The conventional use is upload files by copying * them. DSpace writes the item's bitstreams into its assetstore. Metadata is * also loaded to the DSpace database. * <P> * A second use assumes the bitstream files already exist in a storage * resource accessible to DSpace. In this case the bitstreams are 'registered'. * That is, the metadata is loaded to the DSpace database and DSpace is given * the location of the file which is subsumed into DSpace. * <P> * The distinction is controlled by the format of lines in the 'contents' file. * See comments in processContentsFile() below. * <P> * Modified by David Little, UCSD Libraries 12/21/04 to * allow the registration of files (bitstreams) into DSpace. */public class ItemImport{    static boolean useWorkflow = false;    static boolean isTest = false;    static boolean isResume = false;    static PrintWriter mapOut = null;    // File listing filter to look for metadata files    static FilenameFilter metadataFileFilter = new FilenameFilter()    {        public boolean accept(File dir, String n)        {            return n.startsWith("metadata_");        }    };    // File listing filter to check for folders    static FilenameFilter directoryFilter = new FilenameFilter()    {        public boolean accept(File dir, String n)        {            File item = new File(dir.getAbsolutePath() + File.separatorChar + n);            return item.isDirectory();        }    };    public static void main(String[] argv) throws Exception    {        // create an options object and populate it        CommandLineParser parser = new PosixParser();        Options options = new Options();        options.addOption("a", "add", false, "add items to DSpace");        options.addOption("r", "replace", false, "replace items in mapfile");        options.addOption("d", "delete", false,                "delete items listed in mapfile");        options.addOption("s", "source", true, "source of items (directory)");        options.addOption("c", "collection", true,                "destination collection(s) Handle or database ID");        options.addOption("m", "mapfile", true, "mapfile items in mapfile");        options.addOption("e", "eperson", true,                "email of eperson doing importing");        options.addOption("w", "workflow", false,                "send submission through collection's workflow");        options.addOption("t", "test", false,                "test run - do not actually import items");        options.addOption("R", "resume", false,                "resume a failed import (add only)");        options.addOption("h", "help", false, "help");        CommandLine line = parser.parse(options, argv);        String command = null; // add replace remove, etc        String sourcedir = null;        String mapfile = null;        String eperson = null; // db ID or email        String[] collections = null; // db ID or handles        if (line.hasOption('h'))        {            HelpFormatter myhelp = new HelpFormatter();            myhelp.printHelp("ItemImport\n", options);            System.out                    .println("\nadding items:    ItemImport -a -e eperson -c collection -s sourcedir -m mapfile");            System.out                    .println("replacing items: ItemImport -r -e eperson -c collection -s sourcedir -m mapfile");            System.out                    .println("deleting items:  ItemImport -d -e eperson -m mapfile");            System.out                    .println("If multiple collections are specified, the first collection will be the one that owns the item.");            System.exit(0);        }        if (line.hasOption('a'))        {            command = "add";        }        if (line.hasOption('r'))        {            command = "replace";        }        if (line.hasOption('d'))        {            command = "delete";        }        if (line.hasOption('w'))        {            useWorkflow = true;        }        if (line.hasOption('t'))        {            isTest = true;            System.out.println("**Test Run** - not actually importing items.");        }        if (line.hasOption('s')) // source        {            sourcedir = line.getOptionValue('s');        }        if (line.hasOption('m')) // mapfile        {            mapfile = line.getOptionValue('m');        }        if (line.hasOption('e')) // eperson        {            eperson = line.getOptionValue('e');        }        if (line.hasOption('c')) // collections        {            collections = line.getOptionValues('c');        }        if (line.hasOption('R'))        {            isResume = true;            System.out                    .println("**Resume import** - attempting to import items not already imported");        }        // now validate        // must have a command set        if (command == null)        {            System.out                    .println("Error - must run with either add, replace, or remove (run with -h flag for details)");            System.exit(1);        }        else if (command.equals("add") || command.equals("replace"))        {            if (sourcedir == null)            {                System.out                        .println("Error - a source directory containing items must be set");                System.out.println(" (run with -h flag for details)");                System.exit(1);            }            if (mapfile == null)            {                System.out                        .println("Error - a map file to hold importing results must be specified");                System.out.println(" (run with -h flag for details)");                System.exit(1);            }            if (eperson == null)            {                System.out                        .println("Error - an eperson to do the importing must be specified");                System.out.println(" (run with -h flag for details)");                System.exit(1);            }            if (collections == null)            {                System.out                        .println("Error - at least one destination collection must be specified");                System.out.println(" (run with -h flag for details)");                System.exit(1);            }        }        else if (command.equals("delete"))        {            if (eperson == null)            {                System.out                        .println("Error - an eperson to do the importing must be specified");                System.exit(1);            }            if (mapfile == null)            {                System.out.println("Error - a map file must be specified");                System.exit(1);            }        }        // can only resume for adds        if (isResume && !command.equals("add"))        {            System.out                    .println("Error - resume option only works with --add command");            System.exit(1);        }        // do checks around mapfile - if mapfile exists and 'add' is selected,        // resume must be chosen        File myFile = new File(mapfile);        if (myFile.exists() && command.equals("add") && !isResume)        {            System.out.println("Error - the mapfile " + mapfile                    + " already exists.");            System.out                    .println("Either delete it or use --resume if attempting to resume an aborted import.");            System.exit(1);        }        ItemImport myloader = new ItemImport();        // create a context        Context c = new Context();        // find the EPerson, assign to context        EPerson myEPerson = null;        if (eperson.indexOf('@') != -1)        {            // @ sign, must be an email            myEPerson = EPerson.findByEmail(c, eperson);        }        else        {            myEPerson = EPerson.find(c, Integer.parseInt(eperson));        }        if (myEPerson == null)        {            System.out.println("Error, eperson cannot be found: " + eperson);            System.exit(1);        }        c.setCurrentUser(myEPerson);        // find collections        Collection[] mycollections = null;        // don't need to validate collections set if command is "delete"        if (!command.equals("delete"))        {            System.out.println("Destination collections:");            mycollections = new Collection[collections.length];            // validate each collection arg to see if it's a real collection            for (int i = 0; i < collections.length; i++)            {                // is the ID a handle?                if (collections[i].indexOf('/') != -1)                {                    // string has a / so it must be a handle - try and resolve                    // it                    mycollections[i] = (Collection) HandleManager                            .resolveToObject(c, collections[i]);                    // resolved, now make sure it's a collection                    if ((mycollections[i] == null)                            || (mycollections[i].getType() != Constants.COLLECTION))                    {                        mycollections[i] = null;                    }                }                // not a handle, try and treat it as an integer collection                // database ID                else if (collections[i] != null)                {                    mycollections[i] = Collection.find(c, Integer                            .parseInt(collections[i]));                }                // was the collection valid?                if (mycollections[i] == null)                {                    throw new IllegalArgumentException("Cannot resolve "                            + collections[i] + " to collection");                }                // print progress info                String owningPrefix = "";                if (i == 0)                {                    owningPrefix = "Owning ";                }                System.out.println(owningPrefix + " Collection: "                        + mycollections[i].getMetadata("name"));            }        } // end of validating collections        try        {            c.setIgnoreAuthorization(true);            if (command.equals("add"))            {                myloader.addItems(c, mycollections, sourcedir, mapfile);            }            else if (command.equals("replace"))            {                myloader.replaceItems(c, mycollections, sourcedir, mapfile);            }            else if (command.equals("delete"))            {                myloader.deleteItems(c, mapfile);            }            // complete all transactions            c.complete();        }        catch (Exception e)        {            // abort all operations            if (mapOut != null)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -