All Downloads are FREE. Search and download functionalities are using the official Maven repository.

htsjdk.tribble.util.URLHelper Maven / Gradle / Ivy

There is a newer version: 4.1.3
Show newest version
/*
 * Copyright (c) 2007-2011 by The Broad Institute of MIT and Harvard.  All Rights Reserved.
 *
 * This software is licensed under the terms of the GNU Lesser General Public License (LGPL),
 * Version 2.1 which is available at http://www.opensource.org/licenses/lgpl-2.1.php.
 *
 * THE SOFTWARE IS PROVIDED "AS IS." THE BROAD AND MIT MAKE NO REPRESENTATIONS OR
 * WARRANTES OF ANY KIND CONCERNING THE SOFTWARE, EXPRESS OR IMPLIED, INCLUDING,
 * WITHOUT LIMITATION, WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
 * PURPOSE, NONINFRINGEMENT, OR THE ABSENCE OF LATENT OR OTHER DEFECTS, WHETHER
 * OR NOT DISCOVERABLE.  IN NO EVENT SHALL THE BROAD OR MIT, OR THEIR RESPECTIVE
 * TRUSTEES, DIRECTORS, OFFICERS, EMPLOYEES, AND AFFILIATES BE LIABLE FOR ANY DAMAGES
 * OF ANY KIND, INCLUDING, WITHOUT LIMITATION, INCIDENTAL OR CONSEQUENTIAL DAMAGES,
 * ECONOMIC DAMAGES OR INJURY TO PROPERTY AND LOST PROFITS, REGARDLESS OF WHETHER
 * THE BROAD OR MIT SHALL BE ADVISED, SHALL HAVE OTHER REASON TO KNOW, OR IN FACT
 * SHALL KNOW OF THE POSSIBILITY OF THE FOREGOING.
 */

package htsjdk.tribble.util;

import java.io.IOException;
import java.io.InputStream;
import java.net.URL;

/**
 * Interface defining a helper class for dealing with URL resources.  The purpose of this class is to provide the
 * flexibility to use alternative http implementations, for example Apache HTTPClient, and secondly to provide
 * a hook for clients to inject custom headers, for example oAuth tokens, into the requests.  An instance of
 * URLHelper is created for a URL (there is a 1-1 relation between a URL and HRLHelper).
 *
 * @see HTTPHelper
 * @see FTPHelper
 * @author jrobinso
 * @date Jun 28, 2011
 */
public interface URLHelper {

    /**
     * @return URL of the associated resource
     */
    URL getUrl();

    /**
     * @return content length of the resource, or -1 if not available
     * @throws IOException
     */
    long getContentLength() throws IOException;

    /**
     * Open an InputStream to stream the contents of the resource
     * @return
     * @throws IOException
     */
    InputStream openInputStream() throws IOException;

    /**
     * Open an InputStream to stream a slice (range)  of the resource.
     *
     * May throw an OperationUnsupportedException
     * @param start
     * @param end
     * @return
     * @throws IOException
     */

    InputStream openInputStreamForRange(long start, long end) throws IOException;

    public boolean exists() throws IOException;

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy