org.dspace.ctask.replicate.VerifyAIP Maven / Gradle / Ivy
/**
* The contents of this file are subject to the license and copyright
* detailed in the LICENSE and NOTICE files at the root of the source
* tree and available online at
*
* http://www.dspace.org/license/
*/
package org.dspace.ctask.replicate;
import java.io.IOException;
import org.dspace.content.DSpaceObject;
import org.dspace.core.ConfigurationManager;
import org.dspace.core.Context;
import org.dspace.curate.AbstractCurationTask;
import org.dspace.curate.Curator;
import org.dspace.curate.Suspendable;
/**
* VerifyAIP task will simply test for the presence of a replica representation
* of the object in the remote store. It succeeds if found, otherwise fails.
*
* This task is "suspendable" when invoked from the UI. This means that if
* you run a verification from the UI, this task will return an immediate failure
* once a single object fails the verification. However, when run from the Command-Line
* this task will run to completion (i.e. even if an object fails it will continue
* processing to completion).
*
* @author richardrodgers
* @see TransmitAIP
*/
@Suspendable(invoked=Curator.Invoked.INTERACTIVE)
public class VerifyAIP extends AbstractCurationTask
{
private String archFmt = ConfigurationManager.getProperty("replicate", "packer.archfmt");
// Group where all AIPs are stored
private final String storeGroupName = ConfigurationManager.getProperty("replicate", "group.aip.name");
/**
* Performs the "Verify AIP" task.
*
* Simply tests for presence of AIP in replica ObjectStore.
* @param dso the DSpace Object to verify
* @return integer which represents Curator return status
* @throws IOException if I/O error
*/
@Override
public int perform(DSpaceObject dso) throws IOException
{
if(dso!=null)
{
//NOTE: we can get away with passing in a 'null' Context because
// the context isn't actually used to verify whether an AIP exists
// (see below 'perform(ctx,id)' method)
return perform(null, dso.getHandle());
}
else
{
String result = "DSpace Object not found!";
report(result);
setResult(result);
return Curator.CURATE_FAIL;
}
}
/**
* Performs the "Verify AIP" task.
*
* Simply tests for presence of AIP in replica ObjectStore.
* @param ctx DSpace Context (this param is ignored for this task)
* @param id ID of object to verify
* @return integer which represents Curator return status
* @throws IOException if I/O error
*/
@Override
public int perform(Context ctx, String id) throws IOException
{
ReplicaManager repMan = ReplicaManager.instance();
String objId = repMan.storageId(id, archFmt);
boolean found = repMan.objectExists(storeGroupName, objId);
String result = "AIP for object: " + id + " found: " + found;
report(result);
setResult(result);
return found ? Curator.CURATE_SUCCESS : Curator.CURATE_FAIL;
}
}