org.dspace.content.BitstreamFormat.java Source code

Java tutorial

Introduction

Here is the source code for org.dspace.content.BitstreamFormat.java

Source

/**
 * 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.content;

import java.io.Serializable;
import java.sql.SQLException;
import java.util.List;

import org.dspace.content.factory.ContentServiceFactory;
import org.dspace.content.service.BitstreamFormatService;
import org.dspace.core.Context;
import org.hibernate.annotations.Cascade;
import org.hibernate.annotations.CollectionId;
import org.hibernate.annotations.Type;
import org.hibernate.proxy.HibernateProxyHelper;

import javax.persistence.*;

/**
 * Class representing a particular bitstream format.
 * <P>
 * Changes to the bitstream format metadata are only written to the database
 * when <code>update</code> is called.
 * 
 * @author Robert Tansley
 * @version $Revision$
 */
@Entity
@Table(name = "bitstreamformatregistry")
public class BitstreamFormat implements Serializable {

    @Id
    @Column(name = "bitstream_format_id", nullable = false, unique = true)
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "bitstreamformatregistry_seq")
    @SequenceGenerator(name = "bitstreamformatregistry_seq", sequenceName = "bitstreamformatregistry_seq", allocationSize = 1, initialValue = 1)
    private int id;

    @Column(name = "short_description", length = 128, unique = true)
    private String shortDescription;

    //    @Column(name="description")
    //    @Lob //Generates a TEXT or LONGTEXT data type
    @Column(name = "description", columnDefinition = "text")
    private String description;

    @Column(name = "mimetype", length = 256)
    private String mimetype;

    @Column(name = "support_level")
    private int supportLevel = -1;

    @Column(name = "internal")
    private boolean internal = false;

    @ElementCollection(fetch = FetchType.LAZY)
    @CollectionTable(name = "fileextension", joinColumns = @JoinColumn(name = "bitstream_format_id"))
    @CollectionId(columns = @Column(name = "file_extension_id"), type = @Type(type = "integer"), generator = "fileextension_seq")
    @SequenceGenerator(name = "fileextension_seq", sequenceName = "fileextension_seq", allocationSize = 1)
    @Column(name = "extension")
    @Cascade({ org.hibernate.annotations.CascadeType.ALL, org.hibernate.annotations.CascadeType.DELETE_ORPHAN })
    private List<String> fileExtensions;

    @Transient
    private transient BitstreamFormatService bitstreamFormatService;

    /**
     * The "unknown" support level - for bitstream formats that are unknown to
     * the system
     */
    @Transient
    public static final int UNKNOWN = 0;

    /**
     * The "known" support level - for bitstream formats that are known to the
     * system, but not fully supported
     */
    @Transient
    public static final int KNOWN = 1;

    /**
     * The "supported" support level - for bitstream formats known to the system
     * and fully supported.
     */
    @Transient
    public static final int SUPPORTED = 2;

    /**
     * Protected constructor, create object using:
     * {@link org.dspace.content.service.BitstreamFormatService#create(Context)}
     *
     */
    protected BitstreamFormat() {

    }

    /**
     * Get the internal identifier of this bitstream format
     * 
     * @return the internal identifier
     */
    public final int getID() {
        return id;
    }

    /**
     * Get a short (one or two word) description of this bitstream format
     * 
     * @return the short description
     */
    public String getShortDescription() {
        return shortDescription;
    }

    void setShortDescriptionInternal(String shortDescription) {
        this.shortDescription = shortDescription;
    }

    /**
     * Get a description of this bitstream format, including full application or
     * format name
     * 
     * @return the description
     */
    public String getDescription() {
        return description;
    }

    /**
     * Set the description of the bitstream format
     * 
     * @param s
     *            the new description
     */
    public void setDescription(String s) {
        this.description = s;
    }

    /**
     * Get the MIME type of this bitstream format, for example
     * <code>text/plain</code>
     * 
     * @return the MIME type
     */
    public final String getMIMEType() {
        return mimetype;
    }

    /**
     * Set the MIME type of the bitstream format
     * 
     * @param s
     *            the new MIME type
     */
    public final void setMIMEType(String s) {
        this.mimetype = s;
    }

    /**
     * Get the support level for this bitstream format - one of
     * <code>UNKNOWN</code>,<code>KNOWN</code> or <code>SUPPORTED</code>.
     * 
     * @return the support level
     */
    public int getSupportLevel() {
        return supportLevel;
    }

    /**
     * Set the support level for this bitstream format - one of
     * <code>UNKNOWN</code>,<code>KNOWN</code> or <code>SUPPORTED</code>.
     *
     * @param supportLevel the support level
     */
    void setSupportLevelInternal(int supportLevel) {
        this.supportLevel = supportLevel;
    }

    /**
     * Find out if the bitstream format is an internal format - that is, one
     * that is used to store system information, rather than the content of
     * items in the system
     * 
     * @return <code>true</code> if the bitstream format is an internal type
     */
    public boolean isInternal() {
        return internal;
    }

    /**
     * Set whether the bitstream format is an internal format
     * 
     * @param b
     *            pass in <code>true</code> if the bitstream format is an
     *            internal type
     */
    public void setInternal(boolean b) {
        internal = b;
    }

    /**
     * Get the filename extensions associated with this format
     * 
     * @return the extensions
     */
    public List<String> getExtensions() {
        return fileExtensions;
    }

    /**
     * Set the filename extensions associated with this format
     * 
     * @param exts
     *            String [] array of extensions
     */
    public void setExtensions(List<String> exts) {
        this.fileExtensions = exts;
    }

    /*
    Getters & setters which should be removed on the long run, they are just here to provide all getters & setters to the item object
    */

    public void setShortDescription(Context context, String s) throws SQLException {
        getBitstreamFormatService().setShortDescription(context, this, s);
    }

    public void setSupportLevel(int sl) {
        getBitstreamFormatService().setSupportLevel(this, sl);
    }

    private BitstreamFormatService getBitstreamFormatService() {
        if (bitstreamFormatService == null) {
            bitstreamFormatService = ContentServiceFactory.getInstance().getBitstreamFormatService();
        }
        return bitstreamFormatService;
    }

    /**
     * Return <code>true</code> if <code>other</code> is the same Collection
     * as this object, <code>false</code> otherwise
     *
     * @param other
     *            object to compare to
     *
     * @return <code>true</code> if object passed in represents the same
     *         collection as this object
     */
    @Override
    public boolean equals(Object other) {
        if (other == null) {
            return false;
        }
        Class<?> objClass = HibernateProxyHelper.getClassWithoutInitializingProxy(other);
        if (this.getClass() != objClass) {
            return false;
        }
        final BitstreamFormat otherBitstreamFormat = (BitstreamFormat) other;
        if (this.getID() != otherBitstreamFormat.getID()) {
            return false;
        }

        return true;
    }

    @Override
    public int hashCode() {
        int hash = 5;
        hash += 70 * hash + getID();
        return hash;
    }

}