/** * Copyright (C) 2010 Cloud.com, Inc. All rights reserved. * * This software is licensed under the GNU General Public License v3 or later. * * It is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or any later version. * 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. * */ package com.cloud.storage.template; /** * Download a template file given a URL * @author Chiradeep * */ public interface TemplateDownloader extends Runnable{ /** * Callback used to notify completion of download * @author chiradeep * */ public interface DownloadCompleteCallback { void downloadComplete( Status status); } public static enum Status {UNKNOWN, NOT_STARTED, IN_PROGRESS, ABORTED, UNRECOVERABLE_ERROR, RECOVERABLE_ERROR, DOWNLOAD_FINISHED, POST_DOWNLOAD_FINISHED} public static long DEFAULT_MAX_TEMPLATE_SIZE_IN_BYTES = 50L*1024L*1024L*1024L; /** * Initiate download, resuming a previous one if required * @param resume resume if necessary * @param callback completion callback to be called after download is complete * @return bytes downloaded */ public long download(boolean resume, DownloadCompleteCallback callback); /** * @return */ public boolean stopDownload(); /** * @return percent of file downloaded */ public int getDownloadPercent(); /** * Get the status of the download * @return status of download */ public TemplateDownloader.Status getStatus(); /** * Get time taken to download so far * @return time in seconds taken to download */ public long getDownloadTime(); /** * Get bytes downloaded * @return bytes downloaded so far */ public long getDownloadedBytes(); /** * Get the error if any * @return error string if any */ public String getDownloadError(); /** Get local path of the downloaded file * @return local path of the file downloaded */ public String getDownloadLocalPath(); public void setStatus(TemplateDownloader.Status status); public void setDownloadError(String string); public void setResume(boolean resume); public boolean isInited(); public long getMaxTemplateSizeInBytes(); }