|
|
|
/*
|
|
|
|
irctransferhandler.cpp - IRC transfer.
|
|
|
|
|
|
|
|
Copyright (c) 2004 by Michel Hermier <michel.hermier@wanadoo.fr>
|
|
|
|
|
|
|
|
Kopete (c) 2004 by the Kopete developers <kopete-devel@kde.org>
|
|
|
|
|
|
|
|
*************************************************************************
|
|
|
|
* *
|
|
|
|
* 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 of the License, or *
|
|
|
|
* (at your option) any later version. *
|
|
|
|
* *
|
|
|
|
*************************************************************************
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <kdebug.h>
|
|
|
|
|
|
|
|
#include <kopetetransfermanager.h>
|
|
|
|
|
|
|
|
#include "libkirc/kirctransfer.h"
|
|
|
|
#include "libkirc/kirctransferhandler.h"
|
|
|
|
|
|
|
|
#include "kopetemetacontact.h"
|
|
|
|
#include "irccontact.h"
|
|
|
|
#include "irccontactmanager.h"
|
|
|
|
|
|
|
|
#include "irctransferhandler.h"
|
|
|
|
|
|
|
|
IRCTransferHandler *IRCTransferHandler::self()
|
|
|
|
{
|
|
|
|
static IRCTransferHandler sm_self;
|
|
|
|
return &sm_self;
|
|
|
|
}
|
|
|
|
|
|
|
|
KIRC::TransferHandler *IRCTransferHandler::handler()
|
|
|
|
{
|
|
|
|
return KIRC::TransferHandler::self();
|
|
|
|
}
|
|
|
|
|
|
|
|
IRCTransferHandler::IRCTransferHandler()
|
|
|
|
{
|
|
|
|
connect(handler(), TQT_SIGNAL(transferCreated(KIRC::Transfer *)),
|
|
|
|
this, TQT_SLOT(transferCreated(KIRC::Transfer *)));
|
|
|
|
|
|
|
|
connect(Kopete::TransferManager::transferManager(), TQT_SIGNAL(accepted(Kopete::Transfer *, const TQString &)),
|
|
|
|
this, TQT_SLOT(transferAccepted(Kopete::Transfer *, const TQString&)));
|
|
|
|
connect( Kopete::TransferManager::transferManager(), TQT_SIGNAL(refused(const Kopete::FileTransferInfo &)),
|
|
|
|
this, TQT_SLOT(transferRefused(const Kopete::FileTransferInfo &)));
|
|
|
|
}
|
|
|
|
|
|
|
|
void IRCTransferHandler::transferCreated(KIRC::Transfer *t)
|
|
|
|
{
|
|
|
|
kdDebug(14120) << k_funcinfo << endl;
|
|
|
|
|
|
|
|
IRCContact *contact = IRCContactManager::existContact(t->engine(), t->nick());
|
|
|
|
TQString fileName = t->fileName();
|
|
|
|
unsigned long fileSize = t->fileSize();
|
|
|
|
|
|
|
|
if(!contact)
|
|
|
|
{
|
|
|
|
kdDebug(14120) << k_funcinfo << "Trying to create transfer for a non existing contact(" << t->nick() << ")." << endl;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch(t->type())
|
|
|
|
{
|
|
|
|
// case KIRC::Transfer::Chat:
|
|
|
|
case KIRC::Transfer::FileOutgoing:
|
|
|
|
{
|
|
|
|
Kopete::Transfer *kt = Kopete::TransferManager::transferManager()->addTransfer(
|
|
|
|
contact, fileName, fileSize, contact->metaContact()->displayName(),
|
|
|
|
Kopete::FileTransferInfo::Outgoing);
|
|
|
|
connectKopeteTransfer(kt, t);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case KIRC::Transfer::FileIncoming:
|
|
|
|
{
|
|
|
|
int ID = Kopete::TransferManager::transferManager()->askIncomingTransfer(
|
|
|
|
contact , fileName, fileSize);
|
|
|
|
m_idMap.insert(ID, t);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
kdDebug(14120) << k_funcinfo << "Unknown transfer type" << endl;
|
|
|
|
t->deleteLater();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void IRCTransferHandler::transferAccepted(Kopete::Transfer *kt, const TQString &file)
|
|
|
|
{
|
|
|
|
kdDebug(14120) << k_funcinfo << endl;
|
|
|
|
|
|
|
|
KIRC::Transfer *t = getKIRCTransfer(kt->info());
|
|
|
|
if(t)
|
|
|
|
{
|
|
|
|
t->setFileName(file);
|
|
|
|
connectKopeteTransfer(kt, t);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
void IRCTransferHandler::transferRefused(const Kopete::FileTransferInfo &info)
|
|
|
|
{
|
|
|
|
kdDebug(14120) << k_funcinfo << endl;
|
|
|
|
|
|
|
|
KIRC::Transfer *t = getKIRCTransfer(info);
|
|
|
|
if(t)
|
|
|
|
{
|
|
|
|
t->deleteLater();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void IRCTransferHandler::connectKopeteTransfer(Kopete::Transfer *kt, KIRC::Transfer *t)
|
|
|
|
{
|
|
|
|
kdDebug(14120) << k_funcinfo << endl;
|
|
|
|
|
|
|
|
if(kt && t)
|
|
|
|
{
|
|
|
|
switch(t->type())
|
|
|
|
{
|
|
|
|
// case KIRC::Transfer::Chat:
|
|
|
|
case KIRC::Transfer::FileOutgoing:
|
|
|
|
case KIRC::Transfer::FileIncoming:
|
|
|
|
connect(t , TQT_SIGNAL(fileSizeAcknowledge(unsigned int)),
|
|
|
|
kt, TQT_SLOT(slotProcessed(unsigned int)));
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
kdDebug(14120) << k_funcinfo << "Unknown transfer connections for type" << endl;
|
|
|
|
t->deleteLater();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
connect(t , TQT_SIGNAL(complete()),
|
|
|
|
kt, TQT_SLOT(slotComplete()));
|
|
|
|
|
|
|
|
// connect(kt , TQT_SIGNAL(transferCanceled()),
|
|
|
|
// t, TQT_SLOT(abort()));
|
|
|
|
// connect(kt, TQT_SIGNAL(destroyed()),
|
|
|
|
// t, TQT_SLOT(slotKopeteTransferDestroyed()));
|
|
|
|
|
|
|
|
connect(kt, TQT_SIGNAL(result(TDEIO::Job *)),
|
|
|
|
this , TQT_SLOT(tdeioresult(TDEIO::Job *)));
|
|
|
|
|
|
|
|
t->initiate();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void IRCTransferHandler::tdeioresult(TDEIO::Job *job)
|
|
|
|
{
|
|
|
|
Kopete::Transfer *kt= (Kopete::Transfer *)job; // FIXME: move to *_cast
|
|
|
|
if(!kt)
|
|
|
|
{
|
|
|
|
kdDebug(14120) << k_funcinfo << "Kopete::Transfer not found from tdeio:" << job << endl;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch(kt->error())
|
|
|
|
{
|
|
|
|
case 0: // 0 means no error
|
|
|
|
break;
|
|
|
|
case TDEIO::ERR_USER_CANCELED:
|
|
|
|
kdDebug(14120) << k_funcinfo << "User canceled transfer." << endl;
|
|
|
|
// TDEIO::buildErrorString form error don't provide a result string ...
|
|
|
|
// if (t->)
|
|
|
|
// kt->userAbort(i18n("User canceled transfer."));
|
|
|
|
// else
|
|
|
|
// kt->userAbort(i18n("User canceled transfer for file:%1").arg(t->fileName()));
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
kdDebug(14120) << k_funcinfo << "Transfer halted:" << kt->error() << endl;
|
|
|
|
// kt->userAbort(TDEIO::buildErrorString(kt->error(), kt->fileName()));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
KIRC::Transfer *IRCTransferHandler::getKIRCTransfer(const Kopete::FileTransferInfo &info)
|
|
|
|
{
|
|
|
|
KIRC::Transfer *t = m_idMap[info.transferId()];
|
|
|
|
m_idMap.remove(info.transferId());
|
|
|
|
return t;
|
|
|
|
}
|
|
|
|
|
|
|
|
#include "irctransferhandler.moc"
|