/* * This program is free software; you can redistribute it and/or modify it under the * terms of the GNU Lesser General Public License, version 2.1 as published by the Free Software * Foundation. * * You should have received a copy of the GNU Lesser General Public License along with this * program; if not, you can obtain a copy at http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html * or from the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. * * This program 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. * * Copyright (c) 2006 - 2013 Pentaho Corporation and Contributors. All rights reserved. */ package org.pentaho.reporting.libraries.repository.file; import org.pentaho.reporting.libraries.repository.ContentIOException; import org.pentaho.reporting.libraries.repository.ContentLocation; import org.pentaho.reporting.libraries.repository.DefaultMimeRegistry; import org.pentaho.reporting.libraries.repository.MimeRegistry; import org.pentaho.reporting.libraries.repository.UrlRepository; import java.io.File; import java.io.Serializable; import java.net.MalformedURLException; import java.net.URL; /** * A file-repository uses a subset of the local filesystem to provide a repository view on top of it. This repository * type is the most commonly used repository, as most applications are allowed to access the local filsystem. * * @author Thomas Morgner */ public class FileRepository implements UrlRepository, Serializable { private static final long serialVersionUID = -6221548332596506480L; private MimeRegistry mimeRegistry; private FileContentLocation root; /** * Creates a new repository for the given file. The file must point to a directory. This constructor uses the default * mime-registry. * * @param file the directory, which should form the root of the repository. * @throws ContentIOException if an error prevents the repository creation. */ public FileRepository( final File file ) throws ContentIOException { this( file, new DefaultMimeRegistry() ); } /** * Creates a new repository for the given file. The file must point to a directory. * * @param file the directory, which should form the root of the repository. * @param mimeRegistry the mime registry to be used. * @throws ContentIOException if an error prevents the repository creation. */ public FileRepository( final File file, final MimeRegistry mimeRegistry ) throws ContentIOException { if ( mimeRegistry == null ) { throw new NullPointerException( "MimeRegistry must be given" ); } if ( file == null ) { throw new NullPointerException( "File must be given" ); } this.mimeRegistry = mimeRegistry; this.root = new FileContentLocation( this, file ); } /** * Returns the mime-registry for the repository. * * @return the mime-registry. */ public MimeRegistry getMimeRegistry() { return mimeRegistry; } /** * Returns the repositories root directory entry. * * @return the root directory. * @throws ContentIOException if an error occurs. */ public ContentLocation getRoot() throws ContentIOException { return root; } /** * Returns the URL that represents this repository. The meaning of the URL returned here is implementation specific * and is probably not suitable to resolve names to global objects. * * @return the repository's URL. * @throws MalformedURLException if the URL could not be computed. */ public URL getURL() throws MalformedURLException { return root.getBackend().toURI().toURL(); } }