/* kopetetransfermanager.h Copyright (c) 2002-2003 by Nick Betcher <nbetcher@kde.org> Copyright (c) 2002-2003 by Richard Smith <kopete@metafoo.co.uk> Kopete (c) 2002-2004 by the Kopete developers <kopete-devel@kde.org> ************************************************************************* * * * 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 of the License, or (at your option) any later version. * * * ************************************************************************* */ #ifndef KOPETEFILETRANSFER_H #define KOPETEFILETRANSFER_H #include <tqobject.h> #include <tqstring.h> #include <tqmap.h> #include "kopete_export.h" #include <kio/job.h> namespace Kopete { class Transfer; class Contact; /** * @author Nick Betcher. <nbetcher@kde.org> */ class KOPETE_EXPORT FileTransferInfo { public: enum KopeteTransferDirection { Incoming, Outgoing }; FileTransferInfo( Contact *, const TQString&, const unsigned long size, const TQString &, KopeteTransferDirection di, const unsigned int id, TQString internalId=TQString()); ~FileTransferInfo() {} unsigned int transferId() const { return mId; } const Contact* contact() const { return mContact; } TQString file() const { return mFile; } TQString recipient() const { return mRecipient; } unsigned long size() const { return mSize; } TQString internalId() const { return m_intId; } KopeteTransferDirection direction() const { return mDirection; } private: unsigned long mSize; TQString mRecipient; unsigned int mId; Contact *mContact; TQString mFile; TQString m_intId; KopeteTransferDirection mDirection; }; /** * Creates and manages kopete file transfers */ class KOPETE_EXPORT TransferManager : public TQObject { Q_OBJECT TQ_OBJECT public: /** * Retrieve the transfer manager instance */ static TransferManager* transferManager(); virtual ~TransferManager() {}; /** * @brief Adds a file transfer to the Kopete::TransferManager */ Transfer *addTransfer( Contact *contact, const TQString& file, const unsigned long size, const TQString &recipient , FileTransferInfo::KopeteTransferDirection di); int askIncomingTransfer( Contact *contact, const TQString& file, const unsigned long size, const TQString& description=TQString(), TQString internalId=TQString()); void removeTransfer( unsigned int id ); /** * @brief Ask the user which file to send when they click Send File. * * Possibly ask the user which file to send when they click Send File. Sends a signal indicating KURL to * send when the local user accepts the transfer. * @param file If valid, the user will not be prompted for a URL, and this one will be used instead. * If it refers to a remote file and mustBeLocal is true, the file will be transferred to the local * filesystem. * @param localFile file name to display if file is a valid URL * @param fileSize file size to send if file is a valid URL * @param mustBeLocal If the protocol can only send files on the local filesystem, this flag * allows you to ensure the filename will be local. * @param sendTo The object to send the signal to * @param slot The slot to send the signal to. Signature: sendFile(const KURL &file) */ void sendFile( const KURL &file, const TQString &localFile, unsigned long fileSize, bool mustBeLocal, TQObject *sendTo, const char *slot ); signals: /** @brief Signals the transfer is done. */ void done( Kopete::Transfer* ); /** @brief Signals the transfer has been canceled. */ void canceled( Kopete::Transfer* ); /** @brief Signals the transfer has been accepted */ void accepted(Kopete::Transfer*, const TQString &fileName); /** @brief Signals the transfer has been rejected */ void refused(const Kopete::FileTransferInfo& ); /** @brief Send a file */ void sendFile(const KURL &file, const TQString &localFile, unsigned int fileSize); private slots: void slotAccepted(const Kopete::FileTransferInfo&, const TQString&); void slotComplete(KIO::Job*); private: TransferManager( TQObject *parent ); static TransferManager *s_transferManager; int nextID; TQMap<unsigned int, Transfer *> mTransfersMap; }; /** * A KIO job for a kopete file transfer. * @author Richard Smith <kopete@metafoo.co.uk> */ class KOPETE_EXPORT Transfer : public KIO::Job { Q_OBJECT TQ_OBJECT public: /** * Constructor */ Transfer( const FileTransferInfo &, const TQString &localFile, bool showProgressInfo = true); /** * Constructor */ Transfer( const FileTransferInfo &, const Contact *toUser, bool showProgressInfo = true); /** * Destructor */ ~Transfer(); /** @brief Get the info for this file transfer */ const FileTransferInfo &info() const { return mInfo; } /** * Retrieve a URL indicating where the file is being copied from. * For display purposes only! There's no guarantee that this URL * refers to a real file being transferred. */ KURL sourceURL(); /** * Retrieve a URL indicating where the file is being copied to. * See @ref sourceURL */ KURL destinationURL(); public slots: /** * @brief Set the file size processed so far */ void slotProcessed(unsigned int); /** * @brief Indicate that the transfer is complete */ void slotComplete(); /** * @brief Inform the job that an error has occurred while transferring the file. * * @param error A member of the KIO::Error enumeration indicating what error occurred. * @param errorText A string to aid understanding of the error, often the offending URL. */ void slotError( int error, const TQString &errorText ); signals: /** * @deprecated Use result() and check error() for ERR_USER_CANCELED */ void transferCanceled(); private: void init( const KURL &, bool ); static KURL displayURL( const Contact *contact, const TQString &file ); FileTransferInfo mInfo; KURL mTarget; int mPercent; private slots: void slotResultEmitted(); }; } #endif // vim: set noet ts=4 sts=4 sw=4: