
org.purl.sword.base.Deposit Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dspace-sword Show documentation
Show all versions of dspace-sword Show documentation
DSpace SWORD Deposit Service Provider Extension
The newest version!
/**
* 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.purl.sword.base;
import java.io.File;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import jakarta.servlet.http.HttpServletResponse;
import org.apache.logging.log4j.Logger;
/**
* Represents a deposit.
*
* @author Stuart Lewis
*/
public class Deposit {
private static final Logger log = org.apache.logging.log4j.LogManager.getLogger(Deposit.class);
/**
* The File deposited
*/
private File file;
/**
* The content type
*/
private String contentType;
/**
* The content length
*/
private int contentLength;
/**
* The username
*/
private String username;
/**
* The password
*/
private String password;
/**
* The onBehalfOf value
*/
private String onBehalfOf;
/**
* The slug string
*/
private String slug;
/**
* MD5 hash
*/
private String md5;
/**
* True if verbose should be used
*/
private boolean verbose;
/**
* True if this is a no-operation command
*/
private boolean noOp;
/**
* The packaging format
*/
private String packaging;
/**
* Deposit ID
*/
private String depositID;
/**
* The IP address
*/
private String IPAddress;
/**
* The location
*/
private String location;
/**
* The content disposition
*/
private String contentDisposition;
/**
* Submission created
*/
public static final int CREATED = HttpServletResponse.SC_CREATED;
/**
* Submission accepted.
*/
public static final int ACCEPTED = HttpServletResponse.SC_ACCEPTED;
/**
* @return the authenticatedUserName
*/
public String getUsername() {
return username;
}
/**
* @param username the authenticated UserName to set
*/
public void setUsername(String username) {
this.username = username;
}
/**
* @return the authenticatedUserPassword
*/
public String getPassword() {
return password;
}
/**
* @param password the password to set
*/
public void setPassword(String password) {
this.password = password;
}
/**
* @return the contentLength
*/
public int getContentLength() {
return contentLength;
}
/**
* @param contentLength the contentLength to set
*/
public void setContentLength(int contentLength) {
this.contentLength = contentLength;
}
/**
* @return the contentType
*/
public String getContentType() {
return contentType;
}
/**
* @param contentType the contentType to set
*/
public void setContentType(String contentType) {
this.contentType = contentType;
}
/**
* @return the depositID
*/
public String getDepositID() {
return depositID;
}
/**
* @param depositID the depositID to set
*/
public void setDepositID(String depositID) {
this.depositID = depositID;
}
/**
* @return the file
*/
public File getFile() {
return file;
}
/**
* @param file the file to set
*/
public void setFile(File file) {
this.file = file;
}
/**
* @return the packaging
*/
public String getPackaging() {
return packaging;
}
/**
* @param packaging the packaging to set
*/
public void setPackaging(String packaging) {
this.packaging = packaging;
}
/**
* @return the md5
*/
public String getMd5() {
return md5;
}
/**
* @param md5 the md5 to set
*/
public void setMd5(String md5) {
this.md5 = md5;
}
/**
* @return the noOp
*/
public boolean isNoOp() {
return noOp;
}
/**
* @param noOp the noOp to set
*/
public void setNoOp(boolean noOp) {
this.noOp = noOp;
}
/**
* @return the onBehalfOf
*/
public String getOnBehalfOf() {
return onBehalfOf;
}
/**
* @param onBehalfOf the onBehalfOf to set
*/
public void setOnBehalfOf(String onBehalfOf) {
this.onBehalfOf = onBehalfOf;
}
/**
* @return the slug
*/
public String getSlug() {
return slug;
}
/**
* @param slug the slug to set
*/
public void setSlug(String slug) {
this.slug = slug;
}
/**
* @return the verbose
*/
public boolean isVerbose() {
return verbose;
}
/**
* @param verbose the verbose to set
*/
public void setVerbose(boolean verbose) {
this.verbose = verbose;
}
/**
* Get the IP address of the user
*
* @return the IP address
*/
public String getIPAddress() {
return IPAddress;
}
/**
* Set the IP address of the user
*
* @param IPAddress the IP address
*/
public void setIPAddress(String IPAddress) {
this.IPAddress = IPAddress;
}
/**
* Get the location of the deposit
*
* @return the location of the deposit
*/
public String getLocation() {
return location;
}
/**
* Set the location of the deposit
*
* @param location the location
*/
public void setLocation(String location) {
this.location = location;
}
/**
* Retrieve the filename that is associated with this deposit. This
* is extracted from the content disposition value.
*
* @return The filename.
*/
public String getFilename() {
String filename = null; // default return value
if (contentDisposition != null) {
try {
String filePattern = ".*filename=(.*?)((; *.*)|( +)){0,1}";
Pattern p = Pattern.compile(filePattern);
Matcher m = p.matcher(contentDisposition);
if (m.matches() && m.groupCount() > 2) {
filename = m.group(1);
}
} catch (Exception ex) {
log.error("Unable to extract filename", ex);
}
}
return filename;
}
/**
* Set the content disposition that is to be used for this deposit.
* This will include the filename, if specified.
*
* @param disposition The content disposition value.
*/
public void setContentDisposition(String disposition) {
this.contentDisposition = disposition;
}
/**
* Return the content disposition value.
*
* @return The value.
*/
public String getContentDisposition() {
return this.contentDisposition;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy