/* ============================================================
*
* This file is a part of the rekonq project
*
* Copyright (C) 2007 Lukas Appelhans <l.appelhans@gmx.de>
* Copyright (C) 2008-2009 by Andrea Diamantini <adjam7 at gmail dot com>
* Copyright (C) 2009 by Paweł Prażak <pawelprazak at gmail dot com>
* Copyright (C) 2009 by Domrachev Alexandr <alexandr.domrachev@gmail.com>
*
*
* This program 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 2, or (at your option) 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.
*
* ============================================================ */


#ifndef DOWNLOAD_H
#define DOWNLOAD_H

// Auto Includes
#include "rekonq.h"

// KDE Includes
#include <KIO/FileCopyJob>

// Qt Includes
#include <QObject>

// Forward Declarations
class KJob;

namespace KIO
{
    class Job;
}


/**
 * This class lets rekonq to download an object from the network.
 * Creating a new object, you can continue downloading a file also
 * when rekonq is closed.
 *
 */
class Download : public QObject
{
    Q_OBJECT
    
public:
    enum DownloadType { Save, Open };
    
    /**
     * Class constructor. This is the unique method we need to
     * use this class. In fact Download class needs to know just
     * "where" catch the file to download and where it has to put it
     *
     * @param srcUrl the source url
     * @param destUrl the destination url
     *
     */
    Download(const KUrl &srcUrl, const KUrl &destUrl, DownloadType type);

    /**
     * class destructor
     */
    ~Download();

    KUrl srcUrl() const { return m_srcUrl; }
    KUrl destUrl() const { return m_destUrl; }
    DownloadType type() const { return m_type; }
    void cancel();

signals:
    void downloadFinished(int errorCode);

private slots:
    void slotResult(KJob *job);

private:
    KIO::FileCopyJob *m_copyJob;
    KUrl m_srcUrl;
    KUrl m_destUrl;
    KUrl m_destFile;
    QByteArray m_data;
    DownloadType m_type;
};


// ----------------------


class DownloadManager : public QObject
{
    Q_OBJECT
    
public:
    DownloadManager();
    ~DownloadManager();
    
    /**
    * @short Creates new download job.
    * This method lets you to download a file from a remote source url
    * to a local destination url.
    *
    * @param srcUrl the source url
    * @param destUrl the destination url (default value is your default download destination setting)
    *
    */
    void newDownload(const KUrl &srcUrl, const KUrl &destUrl = KUrl());

    const QList<Download *> &downloads() const;
    
public slots:
    void slotDownloadFinished(int errorCode);

private:
    KUrl downloadDestination(const QString &filename);
    
    QList<Download *> m_downloads;
};


//--


#endif