/* * Copyright (C) 2002-2004 Red Hat Inc. All Rights Reserved. * * This library 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 2.1 of * the License, or (at your option) any later version. * * This library 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 this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * */ package com.arsdigita.cms; import com.arsdigita.domain.DataObjectNotFoundException; import com.arsdigita.mimetypes.MimeType; import com.arsdigita.persistence.DataCollection; import com.arsdigita.persistence.DataObject; import com.arsdigita.persistence.Filter; import com.arsdigita.persistence.OID; import com.arsdigita.persistence.SessionManager; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.math.BigDecimal; import java.util.Locale; /** * An {@link com.arsdigita.cms.Asset asset} describing a concrete * file, such as an image. * * @author Scott Seago (scott@arsdigita.com) * @version $Id: FileAsset.java 2155 2011-01-21 01:17:02Z pboy $ */ public class FileAsset extends BinaryAsset { public static final String BASE_DATA_OBJECT_TYPE = "com.arsdigita.cms.FileAsset"; public static final String CONTENT = "content"; public static final String HEIGHT = "height"; public static final String LENGTH = "length"; public static final String WIDTH = "width"; //public static final String MIME_JPEG = "image/jpeg"; //public static final String MIME_GIF = "image/gif"; /** * Default constructor. This creates a new text asset. **/ public FileAsset() { super(BASE_DATA_OBJECT_TYPE); } /** * Constructor. The contained DataObject is retrieved * from the persistent storage mechanism with an OID * specified by oid. * * @param oid The OID for the retrieved * DataObject. **/ public FileAsset(OID oid) throws DataObjectNotFoundException { super(oid); } /** * Constructor. The contained DataObject is retrieved * from the persistent storage mechanism with an OID * specified by id and * FileAsset.BASE_DATA_OBJECT_TYPE. * * @param id The id for the retrieved * DataObject. **/ public FileAsset(BigDecimal id) throws DataObjectNotFoundException { this(new OID(BASE_DATA_OBJECT_TYPE, id)); } public FileAsset(DataObject obj) { super(obj); } public FileAsset(String type) { super(type); } /** * @return the base PDL object type for this item. Child classes should * override this method to return the correct value */ public String getBaseDataObjectType() { return BASE_DATA_OBJECT_TYPE; } public BigDecimal getWidth() { return (BigDecimal) get(WIDTH); } public void setWidth(BigDecimal width) { set(WIDTH, width); } public BigDecimal getHeight() { return (BigDecimal) get(HEIGHT); } public void setHeight(BigDecimal height) { set(HEIGHT, height); } /** * Retrieves the Blob content. * * @return the Blob content */ public byte[] getContent() { return (byte[]) get(CONTENT); } /** * Sets the Blob content, and sets the length as well. */ protected void setContent(byte[] content) { set(CONTENT, content); setLength(); } public Long getLength() { // just in case setLength(); return (Long) get(LENGTH); } public void setLength(Long length) { set(LENGTH, length); } public void setLength() { Long length = new Long(super.getSize()); setLength(length); } /** * Load the file asset from the specified file. Automatically guesses * the mime type of the file. * * @param fileName The original name of the file * @param file The actual file on the server * @param defaultMimeType The default mime type for the file */ public void loadFromFile(String fileName, File file, String defaultMimeType) throws IOException { // Guess mime type MimeType mime = MimeType.guessMimeTypeFromFile(fileName); if(mime == null && defaultMimeType != null) { // Set default mime type mime = MimeType.loadMimeType(defaultMimeType); } setMimeType(mime); // Extract the filename int i = fileName.lastIndexOf("/"); if(i > 0) { fileName = fileName.substring(i+1); } i = fileName.lastIndexOf("\\"); // DOS-style if(i > 0) { fileName = fileName.substring(i+1); } setName(fileName); FileInputStream in = new FileInputStream(file); readBytes(in); } /** * Write the file asset content to a file. * * @param file The file on the server to write to. */ public void writeToFile(File file) throws IOException { FileOutputStream fs = new FileOutputStream(file); try { fs.write(getContent()); } finally { if (null != fs) { fs.close(); } } } /** * Retrieve all files in the database. Extremely expensive ! * * @return a collection of FileAssets */ public static FileAssetCollection getAllFiles() { DataCollection da = SessionManager.getSession().retrieve (BASE_DATA_OBJECT_TYPE); return new FileAssetCollection(da); } /** * Find all files whose name matches the specified keyword * * @param keyword a String keyword * @param context the context for the retrieved items. Should be * {@link ContentItem#DRAFT} or {@link ContentItem#LIVE} * @return a collection of files whose name matches the keyword */ public static FileAssetCollection getFilesByKeyword( String keyword, String context ) { FileAssetCollection c = getAllFiles(); c.addOrder(Asset.NAME); Filter f; f = c.addFilter("name like (\'%\' || :keyword || \'%\')"); f.set("keyword", keyword); f = c.addFilter("version = :version"); f.set("version", context); return c; } /** * Find all files whose name matches the specified keyword * * @param keyword a String keyword * @return a collection of files whose name matches the keyword */ public static FileAssetCollection getFilesByKeyword(String keyword) { return getFilesByKeyword(keyword, ContentItem.DRAFT); } @Override protected void beforeSave() { if( null == getLanguage() ) { setLanguage( Locale.getDefault().getLanguage() ); } super.beforeSave(); } }